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STANDARO IMPROVED NO-WARP 
CASEORDISKBOX | EASY ACCESS DESIGN 


The MINI-FLEX is styled with low sides and snag-proof 
edges... making removal and replacement of diskettes 
easy and safe. 


The design of the MINI-FLEX case is a unique contribution 
to diskette safety. Many owners keep their disks in the carton 
they came in. Deprived of proper support, diskettes get into ШЕШ, 
a slumped-over posture. But, the MINI-FLEX case is built 

with inclined sections molded into its base. The inclines keep 
diskettes standing upright, assuring no-sag, no-warp storage. 
There's no need to pack diskettes tightly. The MINI-FLEX case 
construction eliminates the need for file drawer type follower 
blocks, which can actually cause compression damage. 


Warped or otherwise distorted disks result in data loss, and 
can even cause costly machine damage and "down" time. The 
inclined sections in the MINI-FLEX bottom prevent ail that 
The MINI-FLEX is a stylish appointment 

in your office environment. 

115 color is impregnated... .it wipes clean with 


just a damp cloth. The case's rounded corners won't snag 
clothing or mar furniture. 


The MINI-FLEX is compact and convenient. It occupies less еее While Guarding Against Data r 1 


desktop space than a piece of typing paper, making for more E 
efficient use of any work station. And since the top nests with D C d B I 
the bottom, you don't need extra space to put it down when ropout ause y mproper 


you take it off. 


An office environment poses some of the worst dangers Stora ge an d Ha ndling . 


to the good health of your diskettes. 


Dust, dirt, and smoke are in the air. 7 а 
Heat and magnetic interference generated by 

office machines create more hazards. They can destroy 

valuable information stored on a disk's magnetic recording 6%" 

material—a risk your diskettes run between the time you жик T 

store data and the time you want it back | | \ 

There are other possible problems, Unregulated vertical E | i | 

storage can lead to sagging, slumping or warping of diskettes. эм: | E тм | 

Horizontal stacking сап cause compression damage. Bending с 246 ст. 1 19? са. — 


or creasing a disk while sorting through a jam-packed box can Specifications: Capacity: 50 Diskettes with Envelopes Ls E. 
result in data loss. Shipping Weight: 3 Lbs./1.35 Kg. Partitions З Color: Smoke and Sand 1 Package MINI-FLEX Guides 


So, you can see, there are a lot of factors that can lead to 


you бте and money replaces аа MINI-FLEX DISKETTE FILE 


MINI-FLEX doesn't conduct heat or electromagnetism like List Price: $29.95 

metal cases do. . Р . 24 95 
Spacious enough to store up to 50 mini-diskettes in their Special rice $ » 
protective envelopes as recommended by all media 

manufacturers, yet small enough to conserve work space. 


The base nests in the lid for a compact configuration in use. Add $2.50 shipping and handling. Use the bind-in card in the 
There's a modern modular concept behind the MINI-FLEX back of the magazine for your convenience in ordering. Tele- 
design. It's adaptable to any quantity of information. ..compact 1 n i 

enough for smaller storage requirements. ..flexible enough for phone orders accepted if charged to credit cards. 


dividing even the largest libraries into convenient units, the 
way separate drawers do in a file cabinet. 


Improper handling of diskettes can cause data loss. With 
the MINI-FLEX, handling is cut down to a minimum. 


In storage, your diskettes are separated by heavy-duty 
partitions, they won't wear out. And they can be moved—or 
removed—as your file grows. When an operator searches for 
a specific disk, the partitions open naturally into V-shaped 
compartments. An operator can view the entire front of each 
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disk's envelope without having to remove the disk from the P.O. Box 5537 
case—or bend it for visibility. That makes for fast accurate Я 
Search and instant identification with no danger of bending Eugene > Or egon 97405 


or creasing vatuable disks. Tel. (503) 485-8796 
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tainment. * And much more. 

Many independent software com- 
also creating programs 

99/1 Home Computer, 
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'e Computing; Micro- 
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Now there are hundreds of additional new uses 
for the Texas Instruments T-994 Home Computer- 
something for every member of your family. 


ware; Charles Mann and Associates 
and many more, 
Get a copy of our Application Pro- 
gram Directory. 


You сап pick up a copy of our latest 
catalog of T1-99/4 software today at 
your nearest Texas Instruments 
Home Computer dealer. 

To receive a copy by 
mail, 


all toll-free 
565. In Texas 
4279. 


Jib 


Congratulations to the. 
winners of our Author aes M Ба 


TUR TX 


СРР 


Fst ize Wirmer 5380040 


Texas Instruments technotogy—brit 


Gen M. ean 
оло, блага CANOA 
[rr 


ae — — m 
Weweiwdmanyimo- йы (фон Ма Rent 
vative and exciting ap- Мез arama рами мет im Mad 
plication programs from Мори ме у Teo T ме, 

Wii аромат да mm 
our recent Author In- Hoy = раме 60 
centive Program. Our Mae: ic d Retard (одн, 
баба наю Mon Rn 
submitted entries. (Program: Mevidalian Inhertancej. Houston. TX 


INCORPORATED 


Man че, Doratt E. Santana 
бааа Segni Ў 
Sum М ча EL 
tein, МА Toe Ars, CA 
озн Я 
imr бли 
mons C бані пеш Larsen 
Жолда А ШООК 
адейі кап Abort 1 Pani 
tim, тя Amit t 
оз Cig Смт Eom Фін 
а Ok іса 
vie ў. ныла кш in 
E fotut OH 
Don eh, se Joy and Noms см 
Thomas Nc оп oH 


ing affordable electronics to your fingertips. 


TEXAS INSTRUMENTS 


E 


el | 
magazine” 


9 How To Write Your Own Programs 
By James |. Dugan | An easy-to-use flowcharting method to help 
beginners get started. 


14 An External Keyboard for the ТІ-99/4 
By Mike Kovacich | Now you can enjoy the best of both worlds: the 
"friendly" console keyboard with its overlays, and an accessory key- 
board for more demanding applications. 


20 A 99'er Review: The Epson MX-80 Dot Matrix Printer 
By G. К. Michaels | Interfacing this popular peripheral through your 
RS-232, and accessing its block-graphics character set. 


Publisher / Editor 
Gary M. Kaplan 


Technical Editors 
William К. Balthrop 
Mike Kovacich 

G. R. Michaels 


Contributing Editors 
Norma & John Clulow 
Steve Kemp 

Mark Moseley 

Regena 

George Struble 
Dennis Thurlow 

Jerry Wolfe 


Production Manager 
Pat Kaplan 


23 Programming Printer Graphics 
Ву Й. К. Balthrop | Developing a “shell” program to get your printer to 
produce letterheads, business forms, charts, graphs, and starships. 


25 Getting Down to Business 
By George Struble | Developing a BASIC program for planning and 
forecasting applications. 


28 How Extended Is Extended BASIC? 
By Gary M. Kaplan | An overview of Tl's new programming language. 


Production & Design 
Greg Davis 

Rod Hoyle 

Chuck Mantell 
Corby Poticha 

Joe Saputo 

Cheryl Vigna 


30 Text-To-Speech on the Home Computer 
By Gary M. Kaplan | The revolutionary communications development. 


36 99'er Reviews: Wildcatting and The Attack 
By W. К. Balthrop | Drill for oil and fight off an invasion of menacing 
spores and crafty aliens. 


39 D-BUG Forum 
By W. K. Balthrop & G. R. Michaels ҒА fix for Checkbook Manager. 


Circulation 
Benjamin Kaplan 
Pat Kaplan 


40 Kelley's Korner: Space & Combat Games in TI BASIC 
By Charles Ehninger, Mark Moseley, & И К. Balthrop | Three super 
programs that pit you against devious foes bent on your destruction. 


48 TMS9900 Machine and Assembly Language 
By Dennis Thurlow { Part | of this tutorial series acquaints you with 
electrical signals, number systems, and CPU architecture. 


52 What Is UCSD Pascal "M . .. And Why Is Everybody Talking 
About It? 
By Gary M. Kaplan | А look at software portability, pseudocode and 
p-machines, and the effect on the T1-99/4 community. 


Advertising 
Patana Ratanapreux 
Tel. 503-485-8796 


55 Third-Party Software Development Systems 
By Gary M. Kaplan | New tools for software developers. 


56 Power-Line Problems in Personal Computers 
By G. R. Michaels | The symptoms and prevention. 


4 


99'er Magazine May/June 1981 


58 


60 


65 


67 


72 


76 


78 


80 


82 


83 


84 


85 


89 


Table of Contents: 


THE INTERNATIONAL JOURNAL OF COMPUTER ASSISTED INSTRUCTION. 


LOGO: A Computer Language as a Learning Environment 
By Daniel Н. Watt | The new high-level language for the Т1-99/4. 


The Lamplighter LOGO Project 
By Henry Gorman, jr, | ^ unique school's experiences with computers. 
LOGO, and young children. 


Ап OnLoCAItion Review: Music Maker 
By Norma & John Clulow | А “command performance" from ТІ. 


A Music Text Editor & File Player for the TI-99/4 
By Norma & John Clulow | А program for writing and performing your 
own computer music, plus the data file for Bach's /nvention in F. 


Tiny Math for Tiny Tots 
By Pat Kaplan & W. K. Balthrop | ^ revolutionary method for teaching 
babies math on the ТІ-99/4. 


Й 


Computer Chess Corner 
By Jerry Wolfe | Learning the game via Video Chess. 


The Texas Instruments TM 990/189 University Module 
By Gary М, Kaplan | А learning device and development tool in one. 


Involving Preservice Teachers With Microcomputers 
By Gary б. Bitter | The TI-99/4 at Arizona State University. 


An OnLoCAltion Review: Santa Paravia and Fiumaccio 
By W. K. Balthrop | A struggle for power in 15th century Italy. 


advoCAlte Course Authoring Guide 
By Marilyn Latham & Gary G. Bitter |. A preliminary look at a new 
CAI courseware production system. 


Spelling Flash 
By Regena | ^ quick ТІ BASIC program for spelling drill. 


Mindstorms 


аце Papert | Thought-provoking excerpts from the LOGO 
“bible?” 


Homework Helper: Fractions 
By Regena | Let the kids check their own homework with this program. 


Publisher's Message 
99'er Bookstore 


64 Dealer Directory 
94 ТІ-99/4 Block Diagram 
Index to Advertisers 


9900 СРО 
PROGRAM COUNTER 


MD 


а 


INSTRUCTION REGISTER 
(ЖЕ: т, Y 
ШШК 

912345678 910012151415 


May/June 1981 


Volume 1 No. 1 


THIS ISSUE'S COVER: 
The theme of this charter issue, The 
Birth of a New Magazine, is depicted 
by the TMS9900 microprocessor crack- 
ing open the egg from which the new 
magazine is emerging. The familiar 
TI-99/4 Keyboard provides the support 
for the new publication's recursive 
vision of the exponential growth of 
16-bit personal computing that will 
parallel the maturation and growth of 
the magazine itself. The cover was de- 
signed by Gary Kaplan and executed by 
Joe Saputo. 


99'er Magazine is published bimonthly by 
Emerald Valley Publishing Co., P.O. Вох 5537, 
Eugene, OR 97405, The editorial office is lo- 
cated at 2715 Terrace View Drive, Eugene, 
OR 97405 (Tel, 503-485-8796). Subscription 
rates іп U.S, and its possessions are $15 for 
one year, $28 for two years, and $39 for three 
years, In Canada and Mexico $18 for one year, 
$34 for two years, $48 for three years, Other 
foreign countries $25 for one year surface, 
$40 for one year air delivery, Single copy price 
іп 0.5. and its possessions 15 $2.95, and $3.50 
in Canada and Mexico. Foreign subscription 
payment should be in United States funds 
drawn on a U.S. bank. Application to rnail at 
controlled circulation postage rates is pending 
at Eugene, OR 97401. POSTMASTER: Send 
address changes to 99'er Magazine, P.O, Вох 
5537, Eugene, OR 97405. Subscribers should 
send all correspondence about subscriptions 
to above address, 


Address all editorial correspondence to the 
Editor at 99'er Magazine, 2715 Terrace View 
Drive, Eugene, OR 97405. Unacceptable 
manuscripts wil! be returned if accompanied 
by sufficient first class postage and self- 
addressed envelope, Not responsible for lost 
manuscripts, photos, or program media, 
Opinions expressed by the authors are not 
necessarily those of 99'er Magazine. АП тай 
directed to the “Letters to the Editor" column 
will be treated as unconditionally assigned for 
publication, copyright purposes, and use in 
any other publication or brochure, and are 
subject to 99'ег Magazine's unrestricted right 
to edit and comment, 99'er Magazine assumes 
no liability for errors in articles or advertise- 
ments, Mention of products by trade name in 
editorial material or advertisements contained 
herein in no way constitutes endorsement of 
the product or products by 99'er Magazine or 
the publisher unless explicitly stated. 


Each separate contribution to this issue and 
the issue as a collective work Copyright 1981 
by Emerald Valley Pubiishing Co. АН rights 
reserved. Where necessary, permission is 
granted by the copyright owner for libraries 
and others registered with the Copyright 
Clearance Center {CCC} to photocopy any 
article herein for the base fee of $1.00 per 
copy of the article or item plus 25 cents per 
page. Payment should be sent directly to the 
CCC, 21 Congress Street, Salem, MA 01970. 
Copying done for other than personal ar іп- 
ternal reference use without the permission of 
Emerald Valley Publishing Co. is prohibited. 
Requests for special permission or bulk orders 
should be addressed to the publisher. 
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ILL. MEER DU n ss 


PUBLISHER’S MESSAGE 


elcome to 99’er Magazine and 
the world of 16-bit personal 
computing. Since this is a 


new publication, Ра like to take this 
opportunity to introduce myself and 
tell you something about what you'll 
find in this issue, and what you can 
expect to find in future issues of this 
magazinc. 

As both publisher and editor, it is my 
responsibility to see that what you 
want to read in 99'er Magazine does, 
in fact, get published. We want you to 
always remember that this magazine is 
written for you. Please feel free to call 
or write me any time with your sug- 
gestions and comments. 

Ме at 99'er Magazine want to sin- 
cerely thank our charter subscribers 
for their support, faith, and best wishes. 
Thanks are also due to our contri- 
buting authors those whose articles 
appear in this issue, as well as those 
whose articles were accepted for pub- 
lication, but because of space limitations 
in this issue, had to be postponed. We'vc 
attracted a talented group of authors, 
and | know that we are all going to learn 
a lot from them in the months ahead. 
Incidentally, three of our contributing 
authors (Charles Ehninger and Norma & 
John Clulow) have won prizes in thc 
recent Texas [nstruments software con- 
test. We're very proud of them. 

Our advertisers also deserve special 
thanks. Their sight-unseen support and 
faith in 99'er Magazine has been es- 
pecially gratifying and encouraging. The 
financial health of a new magazine is 
largely dependent on its advertising 
support, and judging by the warm 
welcome we have received from current 
and future advertisers, it is cvident that 
99'er Magazine is ОН to a good start. 

As morc advertisers become aware of 
this new medium and the readership it 
serves, we all will benefit by having 
access to (1) a /arger variety of new pro- 
ducts that are developed especially for 
this market, (2) better quality prod- 
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ucts resulting from a more competitive 
market, and (3) a larger, monthly maga- 
zine that is made possible by an increase 
in advertising revenue. 

In extending my appreciation to 
everyone who made this publication 
possible, І certainly cannot overlook the 
cooperation we have received from 
Texas Instruments and the various users 
groups around the country. Everyone 
involved was supportive in disseminating 
word of our forthcoming magazine. 


99'er Magazine is indeed fortunate to 
already have a dedicated staff, talented 
authors, and supportive readers and ad- 
vertisers. What we now need to turn this 
winning combination into a smashing 
success is a dynamic increase in the 
number of subscribers and single-copy 
sales. Publishing economics favor larger 
print runs: The more copies you come 
off the press with, the lower the unit 
production cost; this, in turn, allows for 
a more elaborate magazine -- extensive 
use of color, special bind-in supplements, 
and a “fatter” editorial product. 

The fastest way to accomplish 
this is with your help. If each one of our 
subscribers were to find just one addi- 
tional person to subscribe — by giving 
a friend or associate опе of the maga- 
zine's bind-in subscription cards to use — 
we'd be well on our way to achieving 
our projected subscription growth far 
ahead of schedule. Keep in mind that 
many potentia! readers of this magazine 
will not yet have a 9900-based personal 
computer system. For example, your 
friends, business associates, and neigh- 
bors might be interested in microcom- 
puters and want to know more. Or, if 
they already have equipment, they 
might want to feave their 8-bit world 
behind and step up to the many ad- 
vantages of our 16-bit family. 99'er 
Magazine would also make interesting 
reading and be a valuable resource in a 
school or library. And don't forget to 
let your local computer shops know 


By Gary M. Kaplan 


about us. Have them write or call 
for information on our bulk subscrip- 
tion plan for single-copy sales. 


The first thing you have probably 
noticed about 99’er Magazine is that it’s 
not only 99'er Magazine! We've grouped 
together the articles concerned with 
computer-assisted instruction (CAI) in a 
special "magazine within a magazine" 
and called it On LoCA/tion. It will in- 
clude news, applications, and activities 
from all around the United States and 
abroad. I'd like to encourage our readers 
outside the U.S. to submit articles on 
how the Texas Instruments ТІ-99/4 is 
being used as an educational device. In 
this way, On LoCA/tion can truly 
become the /nternational Journal of 
Computer Assisted Instruction — the 
first publication of its kind to provide а 
medium for the international exchange 
of practical СА? applications. 

The second thing you'll notice about 
99'er Magazine is that there's no short- 
age of articles! We've included over 
two dozen entrees on the menu. You 
can choose from tutorials, software list- 
ings, product reviews, “how-to” articles, 
book excerpts, on-the-scene reports, and 
explanations of state-of-the-art technol- 
ogies and products. Whether your 
interest is learning how to write pro- 
grams, modifying your computer hard- 
ware, playing computer games, com- 
posing music, improving your chess 
prowess, learning a new computer lan- 
guage, accessing printer graphics, help- 
ing your children with their home- 
work, developing software to sell, or 
putting your computer to work in your 
business . . . we have something in the 
magazine for you. Our goal in every 
issue is the proverbial-yct-elusive “some- 
thing for everyone." And“everyone” 
means vou ...so let us hear what you 
want to know. 


In our second issue (July/August), 
we'll be starting a "Letters to the Editor" 


column, With your input, there will be 
some interesting correspondence to pub- 
lish. Additionally, you can expect to see 
book reviews, news from the users 
groups, and a “99’ег Bulletin Board” for 
posting of your non-commercial mes- 
sages. (You can start sending them in to 
99’er Magazine/Bulletin Board, P.O. 
Box 5537, Eugene, OR 97405.) 

Other regular columns that will soon 
be started include: 


е Microcomputing for the Handicapped 

* The 99'er Ham Meet (for promoting 
the use of microcomputers in ama- 
teur radio) 

• The Micro Librarian (covering library 
usage of the T1-99/4) 


Several exciting projects are pres- 
ently underway at 99’er Magazine, and | 
thought that this first Publisher's Message 
would be a good time to give you some 
idea of what's coming. First of all, we 
will be acting as a clearinghouse for the 
dissemination of information and activi- 
ties concerned with the LOGO language. 
LOGO users groups can use the pages of 
On LoCAltion to share their discoveries 
and experiences with others around the 
country. But education isn't the only 
thing on our minds. We've also planned 
several book publishing projects includ- 
ing What You Always Wanted to Know 
About the T1-99/4 . . . (there will be a 
user questionnaire in our next issue), 
Extended BASIC Programming on the 
71-99/4, and 9900 Assembly Language 
Programming on the T1-99/4, 

In the coming months ahcad, the 
magazine’s R&D department, 99’ег- 
ware, will be releasing several new hard- 
ware and software products. And plans 
are also underway for providing TEX- 
NET users with the ability to access and 
download the software listings іп this 
magazine. In the July/August issuc, 
we'll provide you with more details 
about the soon-to-be-available TEXNET, 
but in the meantime, read the article on 


page 30 to learn about its text-to-speech 
capabilities. 

Speaking about software, we've got 
some great surprises for you. As you ex- 
plore the magazine, type in the listings, 
and run the programs, you'll see what | 
mean. All the programs are well docu- 
mented, and have been chosen for either 
their entertainment value or utility, as 
well as for their instructive value in 
demonstrating certain programming 
techniques. Incidentally, if you see a 
program listing with a small picture of a 
floppy disk enclosed in a circle with an 
X through it, the program as listed will 
completely fill available memory and 
cannot be run with the disk controller 
turned on (even with the CALL FILES 
(1) command executed}. 


We have a pleasant surprise for 
TI-99/4 users who have been handi- 
capped by having to use a cassette re- 
corder with а remote control jack that 
isn't compatible with the T1-99/4. It 
isn't much of a problem unless you 
want to do file processing on cassette — 
where it's necessary to have the tape 
recorder automatically turned on and 
off under program control. We wanted 
to give you a music text editor program 
(page 68), but knew it would be a 
problem for many readers using re- 
corders with an inoperative remote 
control jack. So we therefore went 
ahead and produced our own inexpen- 
sive TI-SETTE™ adaptor to make the 
incompatible compatible. You’ll find it 
described at the end of the music data 
file on page 70. In future issues, we 
expect to do more with file processing 
on Cassettes, so even if you’re not inter- 
ested in the music software, it might be 
a good idea to get set up for remote 
control operation now. 


INSTRUCTIONS FOR BEGINNERS 


The editorial staff at 99’er Magazine 
has tried to put together a well-balanced 
issue — one written on several levels, for 
the novice and pro alike. We realize that 
many beginners to microcomputing will 
not be able to understand everything 
that's in the magazine. My advice to be- 
ginners, therefore, is to put away the 
issue after you feel you've gotten all 
you're presently capable of absorbing 
from it. Later, several issues down the 
road, go back and re-read any material 
that gave you trouble the first time 
through. Many times you'll be surprised 
to find that you are later able to under- 
stand it. This is all part of the natural 
learning process, and we at the magazine 
will try our best to guide you along on 
that journey of knowledge and dis- 


covery. aq 


Readers With Access to The Source 
May Send Electronic Mail To: 
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Orange Micro 


“THE COMPUTER PRINTER 
SPECIALISTS” 


UP TO 25% DISCOUNTS! — SAME DAY SHIPMENT! 


RADIO SHACK 
CENTRONICS 737 (une PRINTER IV 
Word Processing Print Quality 


- 18 x 9 dot matrix; suitable for word 
processing * Underlining * proportional 
spacing * right margin justification е serif 
typeface % 50/80 CPS е 9%" Pin 
Feed/Friction feed е Reverse Platen * 
80/132 columns 


CENTRONICS 737-1 (Parallel) .. . 
CENTRONICS 737-3 (Serial) 


{List $995) $765 
...(List $1045) 5815 


EPSON MX80/MX70 


Low-Priced 
Professional Print Quality 


«9 х9 dot matrix є Lower case descenders 
» 80 CPS • Bidirectional, Logic seeking е 
40, 66, 80, 132 columns per line * 64 special 
graphic characters: TRS-80 Compatible е 
Forms handling * Multi-pass printing е Ad- 
justable tractors 


EPSON MX80 . 


i (List $645) $Call 
EPSON MX 70 Dot 


..(List $450) 5Са!! 


OKIDATA MICROLINE SERIES 


TRS-80 Graphics Compatibility, 
Friction Feed 


* 9 x 7 dot matrix * 80 CPS е 80, 132 
columns — 64 shapes for charts, graphs & 
diagrams * Double wide characters * 6/8 
lines per inch • Up to З part copy е Friction 
& pin feed * 200 M character head warranty 


OKIDATA M82 Bidirectional, Forms handling 
OKIDATA M83 Wide carriage, 9 x 9 dot matrix 


(List $960) $750 
(List $1260) $1050 


IDS PAPER TIGERS 


Dot Resolution Graphics, quality print, speed 


* 7 wire printhead (445); 9 wire printhead 
(460) with lower case descenders • Over 
150 CPS • bi-directional, logic seeking 
(460) * 8 character sizes; 80-132 columns 
* Adjustable tractors е High-resolution dot 
graphics * Proportional spacing & text 
justification (460). 


105 445G 7 wire printhead, graphics .. 
IDS 4606 9 wire printhead, graphics . . 
1DS 560G 9 wire, wide carriage, graphics 


.... (List $895) $ 750 
. (List $1394) $1150 
(List $1794) $1590 


CALL FOR FREE CATALOG 


(800) 854-8275 
CA, AK, HI (714) 630-3322 


At Orange Micro, we try to fit the right printer to your application 
Call our printer specialists for free consultation. 


VISTA — C. ITOH 


Daisy Wheel Letter Quality 


е 25 CPS (Optional 45 CPS) * Typewriter 
quality * Centronics parallel + RS 232 
Serial (Optional) є. Proportional spacing * 
Bidirectional е Programmable VFU е Зе! 
test » Diablo compatible «Friction feed 
{Optional tractors): * 136 printable 
columns. е Manufactured by C: ITOH, 


(List $1895) - 5 Call 


Low Cost, High Speed, Wide Carriage 
+ 9 x 9 dot matrix е Lower case descenders є Wide carriage * 
Adjustable tractors to 16" « 150 CPS, Bidirectional, Logic Seeking 


ANACOM 150 (List $1350) $ Сан 


АМАОЕХ 
Dot Graphics, Wide Carriage 


е 11 x 9 dot matrix; lower case descenders * Dot resolution graphics 
е Bi-directional, logic seeking * Up to 200 CPS е RS 232 Serial & 
Parallel е» Forms control е X-ON/X-OFF * Up to 6 part copy. 


ANADEX 9501 (List $1650) $1350 


NEC SPINWRITER 
High Speed Letter Quality 
“ 55 CPS « Typewriter quality * Bidirectional е Plotting * pro- 
portional spacing. 
5510-5 RO, Serial, witractors 
5530-5 RO, Parallel, witractors 


TELEVIDEO CRT’S 


AT DISCOUNT PRICES! 


TVI 9120 
ТУІ 920C 
QUANTITY PRICING AVAILABLE TVI 950 


.., {List $2995) $2625 
{List $2970) $2599 


Please Call Toll Free 
Prices are too low to 
advertise 


PRINTERS 


MALIBU 165 wide carriage, graphics, letter quality . . (List $2495) $1975 


QUME 5/45 typewriter quality ‚ (List $2905) $ 2559 
INTERFACE EQUIPMENT 


CCS APPLE PARALLEL interface & cable . . 


APPLE ії - EPSON MX80 
parallel interface board & cable ....................;;; 5 


MICROTRONICS Atari parale! interface. 

ATARI 850 interface module, seriai/paraliel 
TRS-80 CABLES to keyboard or Exp. interface. . 
NOVATION D-CAT direct connect modem 


TELEPHONE ORDERS: Mon-Fri. 8:30 - 5:00 
The Orange Micro Printer Store (Retail): 
Mon-Fri. 10:00 - 6:00, Sat. пі 4:00 


Orange 
Micro. 21 


3150 E. La Palma, Suite 1 
Anaheim, CA 92806 


Phone orders WELCOME: same 
day shipment. Free use of VISA & 
MASTERCARD. Personal checks 
require 2 weeks to clear. Manu- 
facturer's warranty included on all 
equipment. Prices subject to 
revision 


HOW TO WRITE 
J» YOUR OWN PROGRAMS 


Part 1: Using Flowcharts 
To Outline a Solution 


By James J. Dugan 


99/4 and running packaged soft- 

ware may at times stimulate your 
desire to try out some programming of 
your own. If you were fortunate enough 
to have taken some courses in computer 
programming or have had some practical 
on-the-job training, you can probably 
just type up some lines and have the 
computer do what you want. However, 
if your formal training has not included 
this experience, you may soon find the 
frustration of not knowing where to 
start, too much to bear. Well, take heart! 
Іп this article, | am going to present 
some basic information on how you can 
begin programming on your own. 


S itting down in front of your TI- 


A Framework for Writing Programs 


Computer programming is an exercise 
in reasoning and logic. Before program- 
mers can develop software to do specific 
jobs, they must plan their attack on the 
individual elements that are inherent to 
those jobs or problems. This is where it 
is helpful to have in mind a general 
framework as to how to go about solv- 
ing each problem. 

This general framework could take a 
number of different forms. Most will, 
however, contain similar steps. These 
steps can be described as follows. 


1. Define the Problem 

Initially, it is necessary to have a 
good understanding of exactly what you 
want the program to do. If it is possible, 
try to express the problem in a simple 
thought or sentence stating the intended 
outcome of the programming effort. De- 
fining the problem in this manner may 
not only save you time, but may also 
help focus your efforts. 


1031 S. Patton Ct., Denver, CO 80219 


2. Outline the Solution 

This step is the primary purpose of 
this article. We'll get back to examine 
this step in more detail later. 


3. Select the Algorithm 


Many problems requiring a computer 
for solution depend on certain mathe- 
matical algorithms that are required in 
the calculation of the desired solution. 
For those who are puzzled by the word 
"algorithm," mathematicians and math 
teachers use this word to refer to the 
specific method of solving a certain kind 
of mathematical problem. For example, 
you may have been taught to subtract 
whole numbers by placing the larger 
number on top, the smaller on the bot- 
tom and to borrow when necessary. 
This is but one possible algorithm for 
subtraction. In general, you can either 
locate those algorithms that are necessa- 
ry from published sources, or you may 
need to design your own. In either in- 
stance, the simpler the algorithm, the 
better. 


4. Writing the Program 

Many people believe the writing 
or "coding" of a program is what com- 
puter programming is all about. Actual- 
ly, this step is just one in a series of 
steps. Prior planning (as detailed in steps 
1-3, above) is absolutely essential before 
the actual writing of the program can 
begin. And inherent in the writing of 
the program must be a reasonable under- 
standing of the computer language you 
will be using. 


5. Debugging 

Once you have typed the program in- 
to the computer, it is necessary to run it 
to determine if and what difficulties 
exist. You will seldom write an error-free 
program on the first draft. Trying to lo- 
cate and correct those "bugs" can be 


frustrating. This is where some of the 
T1-99/4 built-in features help tremen- 
dously, 


6. Validating the Program 


In this step, you intentionally try to 
locate situations in which the program 
yields inaccurate or undefined solutions. 


7. Documentation 

It is a good idea to document or re- 
cord the characteristics of the program 
for communication of the program’s in- 
tent, its algorithms, and specifications. 
In its simplest form, documentation of 
what each variable represents is helpful. 
Incidentally, when buying a program, 
the author’s documentation (or lack 
thereof} can often be a good indication 
of the quality of the program. 


Outlining the Solution 


The development of an adequate out- 
line is the most critical step in writing a 
program. Many of us novice dabblers in 
the art of programming seem to fail in 
developing an acceptable (let alone, ad- 
equate) outline. My intention here is to 
demonstrate to you some elementary 
outlining techniques—in the hopes that 
we, the dabblers, may be able to improve 
our lot in the somewhat puzzling world 
of bits, bytes, and bugs. 


Flowcharting 


There are a number of methods avail- 
able for outlining a solution to a prob- 
lem. Of those used in computer program- 
ming, basic flowcharting is one of the 
simplest and easiest. 

To introduce you to the flowcharting 
method, let's first look at some of the 
symbols used. 
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ай 


| 


1. START AND END SYMBOL 


aue 


This symbol is used to indicate both the 
beginning and the end of the program. 


2. INPUT-OUTPUT SYMBOL 


E 


The input-output symbol is used to indi- 
cate where the user of the program will 
need to supply a piece of data or where 
a calculation will be printed out for the 
user, 


3. COMPUTATION OR ASSIGNMENT 
SYMBOL 


[ 1] 


This symbol is used to indicate where 
computations or assignments of values 
to variables will occur. 


4. DECISION SYMBOL 


52 


The decision symbol is used to indicate 
where a “yes” or "no" or "true" or 
“false” decision point is located. 


5. STOP SYMBOL 


Г 


This symbol is used in some programs to 
indicate a termination point if this point 
is different from the end point of the 
program, 


There are other symbols that can be 
used according to your needs. Also, re- 
member that no rules exist to stop you 
from developing your own symbols. 


Toward a Workable Technique 


Thc outlining strategy that works best 
for me is to start off simple, and then 
increase the complexity of my outline 
until it does what І want it to do. My 
approach includes (1) writing a sentence 
that defines the problem | want to solve, 
(2) preparing an informal outline, (3) 
developing a more complex flowchart, 
and then (4) writing the program. To 
demonstrate how this approach leads 
you to developing a better program, let's 
take a look at some examples. 


EXAMPLE 1 


For our first example, let's write a 
program that will add two numbers to- 
gether and print their sum. We will de- 
sign the program so that we may input 
two numbers from the console. This is 
called an interactive program, in that 
the user must input the values to be as- 
signed to the variables. Following the 
approach presented, we first define the 
problem: 
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Step 1. Definition of the Problem: 

The program will take two numbers 
being input from the console, add them 
together and print the sum. 


Step 2. Informal Outline: 
1. Start 
2. Input two numbers, A and B 
3. Add A and B 
4. Output the sum of the numbers 


Step 3. Flowcharting: 
Using the flowcharting symbols, the 
solution is further developed. 


Explanation of the flowchart 

Іп examining the flowchart, the 
“flow” is evident in the continuous line 
running from the initial start symbol to 
the final end symbol. The input symbol 
shows that two values are requested, 
with the first input value being assigned 
to the variable A, and the second to B. 
The addition of the two numbers and 
the assignment of their sum to a variable 
occurs inside the computation symbol. 
The value of the sum is then output and 
the program ends. The algorithm neces- 
sary for the solution is shown. 

Now that the problem has been out- 
lined, we proceed to write or code the 
program. 


Step 4. Coding: 


100 REM **ADDITION PROGRAM** 
110 INPUT АВ 

120 LET S=AtB 

130 PRINT S 

140 END 


Explanation of the program. 


The program shows how the original 
intent is followed. 

Line 100 contains a REM statement, 
allowing us a means of identifying the 
program. 

Line 110 allows the uscr to type in 
the two numbers to be added. 

Line 120 assigns the value of A plus 
B to the variable S. 

Line 130 prints the value of S. 

Line 140 ends the program. 


Since my primary intent here is to ex- 
plain how an outline is developed and 


used, | will not explain the TI BASIC 
command statements, but assume that 
readers of this article have already read 
most of the TI Beginner's BASIC, the 
book that came with their computer. 


EXAMPLE 2 


For a more complex example, let's 
develop a program that will select and 
print the larger of two input values. 


Step 1. Defining the Problem: 
Given two numbers, the program will 
select the larger of the two and print it. 


Step 2. Informal Outline: 

1. Start. 

2. Input two numbers, A and B from 
the console. 

3. Compare number A with B. If A is 
larger than B, print A. If A is not 
larger than B, print B. 

4. End. 


Step 3. Flowcharting: 


INPUT A, В 


Explanation of the flowchart. 


The flowchart begins with the start 
symbol. The two values are then input. 
In the decision box, a comparison of the 
value A with B takes place. If the state- 
ment А > B is true, the computer is in- 
structed to bypass the output B box, and 
output the value of A. If the statement 
is false, the computer continues down 
the chart to output the value assigned to 
B. The program then ends. 


Step 4. Coding: 

100 REM **PRINTS LARGER OF TWO 
NUMBERS** 

INPUT A,B 

ЇЕ AB THEN 150 

PRINT B 

GOTO 160 

PRINT A 

END 


110 
120 
130 
140 
150 
160 


Explanation of the program. 

Line 100 is a REM statement used to 
identify the program. 

Line 110 allows the user to input the 
two numbers to be compared. 

Line 120 is the algorithm used to 


compare the two numbers. If the state- 
ment A is greater ( >) than B is true, the 
computer is then instructed to go to line 
number 150 and print A. If the state- 
ment in line 120 is false, the THEN con- 
dition does not hold, and the computer 
continues to the next line. 

Line 130 prints the value of B, as it 
must be the larger. 

Line 140 is used to direct the com- 
puter to go to line 160. Without this 
line, the computer would print the value 
of B, then the value of A. This is, of 
course, not what we wanted. 


One difficulty exists with this pro- 
gram. If A and B are equal, the program 
will not be able to distinguish the two. 
(If this arises, B will be printed.) This 
difficulty could be corrected by allow- 
ing another step for this situation where 
value A equaling value B could be dis- 
played. 


EXAMPLE 3 


Let’s take a look at one more simple 
example. This time we'll try writing a 
program that will print out all thc 
squares of the integers between 1 and 
99, inclusive of the two boundaries. 


Step 1. Defining the Problem: 

The program will makea list of all the 
squares of the integers between 7 and 
99, inclusive. 


Step 2. Informal Outline: 


1. Start. 
2. Let N be a variable whose initial 
value is 1. 


3. Compute the value of N?, and let 
the result be the value of S. 

4. Print N and S on one line of the 
screen. 

5. If the value of N is 99, then end 
the program. Otherwise, go to 
step 6. 

6. Add 1 to the value of N and then 
go back to step 3. 


Step 3. Flowcharting: 


Explanation of the flowchart 


After starting the program, the varia- 
ble М isincreased by 1. As the ТІ BASIC 
will automatically set the initial value 
of М to zero, using the statement N=N+1 
will set the first value of N to 1. Next, 
the square is calculated. Both the inte- 
ger and its square are then printed. The 
next step checks to see if N is equal to 
the upper boundary of 99. If N is equal 
to 99, the computer is instructed to end 
the program. If N is not equal to 99, the 
program loops back to add one to the 
value of N and continues. 


Step 4. Coding: 

100 REM **SQUARES** 

110 LET N=N+1 

120 LET S-N^2 

130 PRINT N,S 

140 IF М()99 THEN 150 ELSE 110 
150 END 


Explanation of the program. 


Line 100 is the REM statement. 

Line 110 adds one to the variable М. 

Line 120 computes the squarc. 

Line 130 prints the integer N and its 
square S. 

Line 140 determines if the value of М 
is 99. If N is equal to 99, the computer 
goes to line 150 and ends the program. 
If М is not equal to 99, the computer 
returns to line 110. 

Line 150 ends the program. 


Now that we have seen the usc of the 
outlining technique in some rather ele- 
mentary program examples, let's get se- 
rious and try something more challeng- 
ing. 


EXAMPLE 4 


Let’s try writing a program to test 
our recall of a series of digits. With cach 
correct matching of the series of digits, 
We'll instruct the computer to add an- 
other digit to the series. 


Step 1. Defining the Problem: 

The program will display a series of 
digits of increasing length and ask the 
user to recall the correct order of the 
digits. 

It might be helpful to place some lim- 
its on the program to further qualify 
what we want it to do. This can be done 
in the informal outlinc. 


Step 2. Informal Outline: 


1. Start. 

2. Have the computer select a ran- 
dom digit. 

3. Display the series of digits for a 
short time. 

4. Clear the screen. 

5. Ask for a response from the user. 

6. Compare the response to the se- 
ries of digits. 

ТА. If the response is correct, congrat- 


ulate and ask if the user wants to 
continuc. 


7B. |f the response is incorrect, show 
the correct series of digits and ask 
if the user wants to continue. 

8. If the user wants to continue, have 
the computer select another digit 
and add it to the end of the pre- 
vious series. 

9. If the user does not want to conti- 
nue, end the program. 


Step 3. Flowcharting: 


SELECT 
DIGIT 


CLEAR 
SCREEN 


INPUT 
RESPONSE 


Explanation of the flowchart. 

After the program starts, a random 
digit is selected. The series of digits is 
displayed and the screen cleared. The 
user is then asked to respond. If the re- 
sponse is correct, thc computer offers 
congratulations with a GOT IT! message, 
then asks if the user wants to continue. 
If the response is incorrect, the computer 
says SORRY!, then displays the correct 
response. The user is then asked if he 
wants to continue. If the answer is yes, 
the computer loops back to the random 
digit selection box, tacks on an extra 
digit to the string, and continues. If the 
answer is no, the program ends. 


Step 4. Coding: 
In coding the program, there are some 
Specific features of TI BASIC that can 
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help us. We'll use the RANDOMIZE 
statement to pick the random digit, and 
the RND function to get a better selec- 
tion of the digits. The necessary algo- 
rithm is developed as follows: Take 
the number generated by the RND func- 
tion and multiply it by 10; then round 
the number using the INT function. This 
algorithm is expressed as ИМТ (ВМО*10). 
To display the series of digits and to 
allow the computer to compare a user's 
response to the original series, it might 
be easiest to translate the digits to a nu- 
meric string. We can perform the trans- 
lation by using the STR$ function. 


Explanation of the program. 


Lines 100-170 are REM statements. 

Line 180 is the RANDOMIZE state- 
ment, 

Line 190 begins the selection of the 
random digit. With this statement, the 
computer will display a series of digits 
starting with a single digit and extending 
to an upper limit of 25 digits maximum. 

Line 200 is the algorithm for select- 
ing the random digit and assigning its 
value to the variable A. 

Line 210 translates the digit selected 
to a numeric string. The line will also 
function in adding each digit selected to 
the end of the previous series of digits. 

Line 220 clears the screen. 

Lines 230-250 present the series of 
digits and tells you how much time you 
are allowed to study the series. 

Line 260-270 time the digits being 
displayed. Going through the FOR... 
NEXT loop takes about five seconds. 

Line 280 clears the screen. 

Line 290 directs the computer to 
jump to line 250 The line is intended to 
get us out of the FOR I... NEXT I 
loop without disrupting it. 

Line 300 continues the FOR I... 
NEXT I loop. 

Line 310 ends the program. 

Line 320-330 prompt the user to 
respond. 

Line 340 compares the response to 
the series of digits. If the response is in- 
cortect, the THEN condition directs the 
computer to line 380 which is the 
SORRY! comment. If the response is 
correct, the THEN condition does not 
hold, and the computer goes to the next 
line (line 350). 

Line 350 clears the screen. 

Line 360 congratulates the user. 

Line 370 directs the computer to go 
to line 390, bypassing the SORRY! 
comment, 

Line 390 asks if the user wants to 
continue. 

Line 400-410 check to see if the user 
is interested in continuing. 

Line 420 returns the computer back 
into the FOR I... NEXT І loop. 

Line 430 ends the program. 
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FINAL COMMENTS 


Once you've had a chance to use this 
approach—defining the problem, doing 
an informal outline, flowcharting, and 
then coding—in a project of your own, 
programming your computer will no 
longer be as forbidding and mysterious 
as you first thought. 

Before attempting programs of your 
own, you may want to try a little exer- 
cise. Add the following features to the 
previous program: 

(1) Allow the user to choose how 
much time the digits are displayed on 
the screen. 

(2) ІГ response is correct, play a 
3-note chord. 

(3) If response is incorrect, play one 
note of noise, and print a screen message 
that tells how many digits were contained 
in the largest number correctly guessed. 

The solution, in the form of an ex- 
panded program will appear in the next 


issue. a 


REM 333312121)3111211* 
REM кає xk 

REM 13$NUMBER MATCHS# 

REM #48 зг 

REM заза заза 

ВЕМ 

REM BY JAMES DUGAN 

REM  99'ER VERSION 5.81.1 
RANDOMIZE 

FOR Ізі TO 25 

LET AxINT(RNDt10) 

LET MSG$-MSGSMSTRS (А) 

CALL CLEAR 

PRINT "HERE IS THE NUMBER":: 
PRINT MSG$::i: 

PRINT "YOU HAVE FIVE SECONDS": 
"TO STUDY IT" 

FOR DELAY=1 TO 1500 

NEXT DELAY 

CALL CLEAR 

60508 520 

NEXT I 

GOTO 430 

PRINT "TYPE THE NUMBER" 

INPUT RES$ 

IF RES$<>MSG$ THEN 580 

CALL CLEAR 

PRINT "GOT ІТ!" 

GOTD 390 

PRINT “SORRY! THE NUMBER WAS: " 
3М55% 

PRINT "DO YOU WANT TO CONTINUE 
? eaves, OR "ме." 

INPUT ANSS 

IF ANSS<>"Y"THEN 450 

RETURN 

END 


the 99’er 
BOOKSTORE 


Texas Instruments 
TI-99/4 
Console only $499 
Modulator 41 
Disk Controller | 243 
Disk Drive 399 
RS232C 183 
Telephone Coupler 183 
Thermal Printer 325 
Speech Synthesizer 122 
32K RAM Memory 325 
Extended BASIC Module 81 
Remote Controllers 28 
Casette Cable 14 


We stock all TI-99/4 Software 
Prices FOB Lexington, KY 
Add $4 for shipping 
Credit Card Orders add 496 
KY Residents add 5% tax 


СЕМ inc. 


198 Moore Dr. 
Lexington, KY 40503 
Ph (606) 276-1519 


New— 
Joystick 
Adapter 
for the TI-99/4 


е Allows you to use the 
smoother, faster - acting 
Atari video game joysticks 
(available everywhere for 
under $10 each) 


A MUST for The Attack, 
Indoor Soccer, & Video 
Graphs 
Plugs into the joystick 
connector on your 99/4 
console, and accepts 
either 1 or 2 Atari Joy- 
sticks 
Adapter only—$20 postpaid 
(joysticks additional) 
Dealer Inquiries Invited 
Order from: 
DENALI DATA 
1413 N. McKinley 
Oklahoma City, OK 73106 
Tel. (405) 524-7764 
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If you p 


just bought 


another 
printer, 
boy are 


you gonna 


be sorry. 


The Epson MX-80. It’s not just another worked- 
over rehash of last year’s model. It’s our top-of- 
the-line 80-column printer. It's new. From the 
ground up. And it's the most revolutionary 
printer to hit the market since Epson invented 
small printers for the 1964 Olympics in Tokyo. 
Don't take our word for it, though. Compare. 
There simply isn't a better value in an 80-column 
printer. Period. 

But here's the fact that's going to stand the 
printer world on its ear. The MX-80 sports the 
world's first disposable print head. After it's 
printed about 50 million characters, you can 
throw it away. Because a new one costs less than 
$30, and the only tool you need to change it is at- 
tached to the end of your arm. 

Now that's revolutionary, 
but that's only the beginning. 
The MX-80 also prints bidirec- 
tionally at 80 CPS with a logi- 
cal seeking function to mini- 
mize print head travel time 


The world's first disposable print 
head. 1t has a life expectancy of over 50 
million characters, yet it's so simple, 
you can change it with one hand. And it 
costs less than — repeat less than - $30. 


and maximize throughput. It prints 96 ASCII, 
64 graphic and eight international characters in 
a tack-sharp 9x9 matrix. And it provides a user- 
defined choice of 40, 80, 66 or 132 columns and 
multiple type fonts. 

We spent three long years developing the 
MX-80 as the first of a revolutionary series of 
Epson MX Printers. We employed the most ad- 
vanced automatic assembly and machining 
techniques in existence to produce a printer that 
is incredibly versatile, remarkably reliable and 
extraordinarily inexpensive. It's a printer that 
could only come from the world's largest man- 
ufacturer of print mechanisms: Epson. 

If it sounds like we're proud of the MX-80, we 
are. Not only does it do things 
some of the world's most ex- 
pensive printers can't do, it'll 
do them for you for less than 
$650. That's right. Under $650. 

And if that isn't revolution- 
ary, we don't know what is. 


EPSON 


23844 Hawthorne Boulevard, Torrance, California 90505, Telephone (213) 378-2220 
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The Best of Both Worlds 


An External Keyboard for the TI-99/4 


has its definite advantages in an educational and 

game-playing environment, a more standard, terminal- 
like keyboard would be more suitable for data and word 
processing, communications, and program development. In 
this article, ! will present a method of attaching an external 
keyboard to your 99/4 console. In future articles, | will ex- 
plore several possible hardware configurations for this modi- 
fication, and weigh the advantages and disadvantages of 
each, so that you can decide which method is most appro- 
priate for you. None of the methods that | will employ will 
involve the disabling of the console keyboard. You'll always 
retain "dual control" of your computer, and will never have 
to sacrifice the overlay advantages and "'friendliness" of the 
original. 

In Figure 1, you can observe the eighteen connections to 
the keyboard. Ten of the lines—for explanation purposes | 
will call scan lines—originate from the 7415156. Actually, 
there are five scan lines that are connected to one half of 
the keyboard, and then are wired in parallel to the other 
half of the keyboard. There are aiso four lines on each side 
of the keyboard that | will call interrupt lines. These lines 
are connected to the interrupt inputs of the TMS9901 /О 
controller, I’ve numbered all eighteen lines at the keyboard, 
and have made a chart (Table 1) to distinguish between the 
scan and interrupt lines. 


А Ithough the unique keyboard оп the T1-99/4 console 


By Mike Kovacich 


The basic operation of the ТІ-99/4 keyboard is quite 
simple. The TMS9901 outputs 3 bits of data to the inputs 
of a decoder (741-5156); the selected decoder output is 
then inverted and forced into a /ow state. As a result, only 
one of the scan lines is /ow at this time. All of the scan lines 
are normally Aigh because of pull-up resistors, so only one 
scan line at a time is selected as a /ow level. The 3-bit data 
output from the TMS9901 is continuously changing-—thus, 
the "scanning" effect. 

When a keyswitch is closed, the corresponding row (inter- 
rupt line) is brought /ow when the 9901 selects the согге- 
sponding column (scan line). 

An interrupt is generated and tells the microprocessor 
that a key was depressed. The microprocessor looks at what 
interrupt line caused the interrupt and which scan line was 
selected at the time of the interrupt. The internal software 
determines what value to give to that key. 

Now that you basically know the operation of the key- 
board, you are ready to connect an external keyboard to 
your ТІ-99/4. 

Early in my planning stage, І decided to mount а 25-pin, 
D-type (DB/25) female connector to the back of my con- 
sole (see Photo 3). The interrupt and scan lines were brought 
to this connector; so different external keyboard configura- 
tions could be tried without having to take apart the con- 
sole over and over again. І also decided to connect the *5V, 


ANM 
) TO JOYSTICK 


Figure 1 


ТМ59901 


14 99er Magazine May/June 1981 


Photo 1 


None of the 
methods involve 
the disabling of the 
console keyboard. 
You'll always retain 
dual control of 
your computer, 

and will never һауе 
to sacrifice the ча 
overlay advantages 
and friendliness 

of the original. 


—5V, +12V, GND and external speaker to this connector; 
so an external power supply would not be necessary. 

1 have provided a table of the pin-outs | used, and suggest 
that you use the same for future compatibility. Besides the 
female DB/25 chassis connector, the only other parts needed 
to modify the console are an 18" length of 13-conductor 
color-coded ribbon cable, and four color-coded 18" lengths 
of #18 wire. If you want to mount the DB/25 connector 
on the back panel, the plastic housing will have to be phy- 
sically modified. This means that a drill, hacksaw, some files, 
as well as some type of glue will all be necessary. 

With all its cables removed (including power), place the 
unit with the keyboard face down. Put a towel underneath 
to prevent the front surface from being scratched. The bot- 
tom shell can be easily separated from the main body by 
removing the screws that hold it in place. It will be neces- 
sary to dismantle the power switch assembly to remove the 
bottom shell. Once the bottom is removed, study the power 
switch assembly, and practice putting it together and taking 
it apart a few times. If you have dared to go this far and 
your heart is thumping too fast, don't worry. A lot of de- 
sign work has gone into the physical mounting and electri- 
cal shielding of the logic board; nothing.you have done so 
far could damage the computer. (To play it safe, however, 
you might want to reconnect the power and video, and go 
through a small test procedure after each major step.) This 
is all the dismantling of the console you will have to do. 

With the bottom off, all of the points that you will solder 
to are fully exposed. Please refer to Photo 2, and note 
where the wires from the connector are soldered to the 
logic board. It is difficult to see all of the solder points from 
the photograph; so I’ve drawn a pictorial diagram (Figure 2) 
to identify each solder point. As they say in all the pirate 
movies, “Ап X marks the spot." By the way, you'll only 
need to bring thirteen of the eighteen keyboard lines to the 
08725 connector. This is because five wires on the scan lines 
are duplicated. There's no need to wire them up as long as 
you remember to reduplicate them at the new Keyboard. 
The numbers in Figure 2 identify the keyboard lines (see 
Figure 1 and Table 1). 


As mentioned earlier, you'll have to modify the plastic 
housing if you want a secure connection. So get your hack- 
saw ready and refer to Figure 3. Measure a 3” piece of the 
leaf on the backside of the bottom shell (Figure 3a), and 


carefully cut it out. The DB/25 female connector is mounted 
on this piece of plastic. Drill and file the plastic piece until 
the connector properly fits in place. The 4 measurement 
in Figure 3b is critical because of the limited room inside 
the 99/4 console. 

You may now proceed to solder the leads for the key- 
board lines and power supply—first to the DB/25 connector, 
and then to the appropriate points on the logic board. It's а 
good idea to write down (on a separate piece of paper) 
what color wire is soldered to what pin on the connector, 
50 you can easily tell them apart. Use heat-shrink tubing on 
every pin to eliminate any possible shorting at the connec- 
tor end. Once the wires have been soldered to the connec- 
tor using the pin-outs of Table 1, route the group of wires 
underneath the logic board as in Photo 2. Cut off excessive 
wires lengths and proceed to solder the wires to the logic 
board. Use a cable tie or tape to group the wires together 
for neatness. 


Once again, check to see if you have made the right con- 
nections. If you're sure that no mistakes were made, pro- 
ceed to glue the connector assembly to the console as in 
Figure Зс. І used a hot glue gun which works very well with 
plastic. Photo 3 shows the connector glued in place. 


While you are waiting for the glue to harden, you сап 
prepare the connecting cable assembly. This cable connects 
the external keyboard to the connector that was just 
mounted on the back of the 99/4 console (see Photo 4). A 
color-coded multi-conductor cable (or ribbon cable) and a 
male DB/25 connector are needed for this assembly. The 
cable must have a minimum of fifteen conductors. The 
pin-out must be identical to the pin-out of the chassis 
mounted connector. Write down on paper the color of wire 
that was soldered to each pin (as you did with the ribbon 
cable earlier). This will make it very easy to identify the 
coded wires at the opposite end of the cable—the end that 
goes to the external keyboard (as in Photo 1). 


By the time you finish wiring up the cable, the glue 
should be quite hard. Make sure there is no excessive glue 
around the edges of the plastic. It's a good idea to lift the 
console and shake loose any piece of solder or wire that 
might have fallen inside the console. The bottom shell can 
now be put back on the console. Insert the power switch 
lever into place, and fasten the bottom with the screws. 
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Figure 2 
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LOGIC BOARD 


POWER SUPPLY 


Re-connect the power and video, and test the operation 
of the computer. All the keys should work as before. If by 
chance, some keys do not function properly, power down 
immediately; re-open the console, and check your solder 
connections. Also, look for solder bridges near the points 
where you soldered. Otherwise, if everything works fine, 
you have completed a major step and deserve a cup of 
coffee, 

Before you plug in the connecting cable with the male 
DB/25 at one епа, "таке sure all the power supply lines (at 
the open end of the cable) are isolated from the keyboard 
lines. To test the cable assembly and your console modifi- 
cation, refer to Figure 1 and the sheet of paper you used to 
identify the color-coded wire in the cable assembly. Plug in 
the male DB/25 connector into the console and turn on the 
computer's power. Take keyboard scan line 1 and interrupt 
line 8, and short them together. The character "1" should 
appear on the display. If you short scan line 3 and interrupt 
line 8, the character "2" will be displayed. If more than опе 
character appears on the display, it's because you are not 
making a solid contact. But if no characters appear, then 
you might have identified the wires incorrectly, Trace back 
until you find your error. There is a complete list of charac- 
ters with their coordinates in Table 2. You will have to 
match these coordinates with whatever keyboard you wish 
to use, 

Choose a keyboard that has easy access to all the traces 
on both sides of the printed circuit board, since you will 
probably have to remove the keyswitches and cut all the 
interfering traces. Once all the trace cuts havc been made, 
replace the keyswitches and wire-up the keyboard matrix 
the same as the console keyboard in Figure 1. 


Photo 2 
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Keyboard Lines DB/25 


і ооо челом 


Power Supplies 


-5М 
*12V 
+5V 

GND 


Table 1. Keyboard Connector Pin-out 


= = arSuURVEY 
READERS INTERESTED 
IN HAVING THIS 
MODIFICATION DONE 
FOR THEM, PLEASE LET 
US KNOW. ADDRESS 
YOUR INPUT TO: 


99’er SURVEY - KB1 
P.O. Box 5537 
Eugene, OR 97405 


If you're working with a standard keyboard, the SHIFT 
keys can be connected in parallel. The RETURN key can be 
wired as the ENTER key. The set of keytops you have, will 
probably not match the console keyboard(especially the 
top row). There wil! also be quite a few unused keys such 
as the one containing the question mark and slash. My pur- 
pose in this first article is to show you how to interface a 
minimum-configuration external keyboard. You'll want to 
give considerable thought to your choice of what particular 
keyboard to use, since the characteristics of the keyboard 
will ultimately affect how much you actually gain from the 
enhancement. 

You can also add remote controls for your game pro- 
grams. For example, the Footba// Command Module uses 
four keys per player. Once the time limit and team names 
have been entered, player A uses keys "1" and “2” to select 
and enter his plays; player B uses keys "8" and “9”. Both 
players use the "С" key to start their plays, and the “Т” 
key for time-outs. Figure 4a shows one possible configura- 
tion of the controls. Seven wires would be.required for each 
control (see Figure 4b), and would be plugged directly into 
the external keyboard connector. Instead of both players 
awkwardly trying to access the console keyboard at the 
same time (and getting sore eyes from being too close to 
the monitor or TV), they can sit comfortably in their own 
chairs and get more enjoyment out of the game. 

It's important to note that both the external keyboard 
and the remote controls do not interfere at all with the nor- 
mal operation of the console keyboard. And although the 
external keyboard presented in this article leaves a lot to be 
desired, the connector we mounted on the back of the ТІ- 
99/4 console will, in fact, allow more sophisticated keyboard 
designs to be easily implemented. 


Key-Scan-Int. Key-Scan-Int. 


1 1- 8 SP 

2 3- 8 A 
3 5 - 8 5 

4 7- 8 D 
5 9- 8 E 
6 1-17 G 
7 3 - 17 Н 
8 5 — 17 ] 

9 7 — 17 K 
0 9 — 17 |4 
Q 1- 6 SH 
М-3- 6 Z 
E 5 - 6 X 
R-7- 6 С 
Т 9- 6 У 
Ү 1-15 В 
U 3 — 15 N 
І 5 - 15 М 
0-7 - 15 
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Table 2. Table of Key Co-ordinates 
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In the next issue, І will show you how to add single-key 
functions to your external keyboard. You will be able to 
move the cursor left or right, delete or insert characters, 
erase lines, or use the edit functions all by individual key- 
stroke. І will also discuss the use of a microprocessor-con- 
trolled external keyboard which | am currently designing. 


By using a microprocessor, the standard keyboard we con- 


песі to our console can have extra enhancements such as 
auto-repeat and pre-programmed string keys. Watch for 
all this in future issues. @ 
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PROFESSIONAL. 
SOFTWARE 


for the TI-99/4 


Accounts Receivable 

Accounts Payable 

Inventory 

General Ledger 

Package (All 4 Systems) . . . . $350.00 


* Disk-Based, 1 or More Drives 
Ф Supports RS-232 
* Full Documentation 


For More Information Contact : 


W. R. Wilson Co. 
928 North Apple St. 
Greenfield, IN 46140 
Tel. (317) 462-9511 
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DISK DRIVE WOES? 
PRINTER INTERACTION? 
MEMORY LOSS? 
ERRATIC OPERATION? 


Don't 
Blame The 
Software! 


Power Line Spikes, Surges & 

Hash could be the cutprit! 

Floppies, printers, memory & processor often interact! Our unique 
ISOLATORS eliminate equipment interaction AND curb damaging 
Power Line Spikes, Surges and Hash. 


* ISOLATOR (150-1) 3 filter isolated prong sockets; integral 
Surge/Spike Suppression; 1875 W Ma: load, 1 KW load any 
Socket ......... . $62.95 

* ISOLATOR (150-2) 2 fi 
sockets total); Integral Splke/Surge 
load, 1 KW either bank 

* SUPER ISOLATOR (150-3), sImilar to ISO-1 except double 
{tering & Yr ression . . 

* ISOLATOR (150-4), similar 
Individually filtered sockets 

* ISOLATOR (150-5), similar to 
banks, 9 sockets total ... .. 

* CIRCUIT BREAKER, апу model (add-CB) 

* СКТ BRKR/SWITCH/PILOT (СВ5)... - 

Master-Charge, Visa, American Express 
Order Toil Free 1-800-225-4876 
(except AK, НІ, MA, PR & Canada) 


MORE GOOD NEWS 


FROM 


MARINGHIP 


SYSTEMS 


OFF-THE-SHELF 16-BIT HARDWARE AND SOFTWARE 


16-BIT HARDWARE 


Why wait when you want a state of the 
art 16-bit microcomputer? At Marinchip 
Systems, we believe in being respon- 
sive to your needs. So when you want 
a system that delivers, call Marinchip 
Systems, because we have it in stock. 


* $-100 CPU board 

* TMS9900 microprocessor from 
Texas Instruments 

* Support for 8-bit and 16-bit memories 
and peripherals 

* Software included with CPU 

* CPU price - $700. 

* 64K byte memory with 16-bit access, 
bank-select for multi-user systems - 
$1050. 

* Quad 510 board with four program- 
mable asynchronous or sychronous 
ports - $350. 

* Complete systems (except CRT) with 
1 Megabyte floppy disc storage - 
$5500. 

* Hard disc available. 


CBASIC is a trademark of Compiler Systems 


Marinchip Systems 


16-BIT SOFTWARE 

Because we're a total computer 
company, we also carry our series of 
the most complete and flexible software 
systems available anywhere. So when 
you want the software that delivers, 
call Marinchip Systems, because we 
have it in stock. 


* Single-user Disc Executive - free 
with CPU 

* BASIC interpreter, relocatable 
assembler and linker, debug monitor, 
utilities - free with CPU 

* EDIT: Context editor with the same 
features found on UNIVAC, COC, 
DEC systems - free with CPU 

* WORD: Document formatter with 
justification, page numbers, user- 
specified headings and footings, 
macro expansion, copy from disc, 
and more - free with CPU 

* WINDOW: Simplest, most powerful 
screen editor you can buy - $250. 

* Extended Commercial BASIC: inter- 
preter with 16-digit precision, 


Computer Power and Human Reason 
16 St. Jude Road 


Print Using, random access disc files 

- $120. 
* PASCAL: Brinch Hansen's Sequential 

Pascal - $150. 
* Applications: The Osborne General 
Ledger, Accounts Payable / Receiv- 
able, Payroll, full source in QBASIC - 
$150. each 
NOS: Multi-user operating system 
with byte-addressable device- 
independent files, hierarchical file 
system, read / write /execute pro- 
tection, print spooling, background 
batch, upward compatible from Disc 
Executive - $250. 
QBASIC: Extension of CBASIC 27u 
that generates fast machine code for 
the 9900. New and unique options 
include fast binary 1/0, separate 
compilation of functions, assembly- 
language functions - $220. 
Documentation: CPU, free software 
package, PASCAL, NOS - $40 - 
applicable to purchase; QBASIC - $20; 
Applications - $25 each 


* 


* 


* 


Mill Valley, CA 94941 
415/383-1545 
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Dot Matrix 
Printer 


By G. В. Michaels 


The way many Epson MX-80 owners have talked with 

affection about their “magnificent machines,” made 
me wonder...Then someone told me about an MX-80 
user’s group. “А user’s group for a printer? Who are you 
trying to kid, fella...” 

As it turned out, the “Epsoniac” was speaking the truth; 
A user’s group did indeed exist! My curiosity was piqued. | 
just had to try an MX-80 for myself. 

Using any printer, other than the TI Thermal Printer, 
with the ТІ-99/4 requires that it be compatible with the 
RS-232C industry standard. To connect the MX-80, | there- 
fore needed the separate Epson RS-232C Serial Interface 
card. (Without this circuit board, the MX-80 can connect 
directly only to computers with a Centronics-style 8-bit 
parallel port). The RS-232C serial interface is the most 
commonly used interface in computer systems; all data bits 
are lined up sequentially and sent along the bus communi- 
cation lines as a long string of information. 

Installing the interface is easy: Remove four screws 
on the bottom of the case, and pull off the roller knob 
from its shaft; this allows you to lift off and partially sepa- 
rate the upper case from the printer mechanism (with the 
cables still connected). The serial interface board simply 
plugs into the connector on top of the control circuit board, 
and is held down with four screws in the corner mounting 
poles. Incidentally, the bottom circuit board has two dip 
switches that allow you to choose desired control modes. 
About the only two factory-set options that | might some- 
day change are the ones that allow special symbols for use 
in France, Germany, and England, and the change-over from 
the built-in block graphics character set to the Japanese Ka- 
takana alphabet. (You just never know when you'll have to 
dash off a letter in Katakana...) 

The RS-232C serial interface board that is mounted on 
top of this control board (the large, dark square area near 
the top of the photograph) also has a dip switch that allows 
users to customize the printer to their particular specifica- 
tions. By throwing a combination of very tiny switches you 
can choose the transmission bit rate (from 75 to 9600 Baud), 
the word length (7-bit or 8-bit), and whether a parity check 
is to be enabled (and if so, a choice of odd or even). Al- 
though this dip switch does, in fact, give a user great flexibi- 


| 5 it possible to have a “love affair" with a printer? 
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lity in configuring the printer to changing needs, reaching it 
does necessitate removing four screws, the roller knob, and 
the top cover; so I'd recommend planning your particular 
applications ahead of time, and setting the switches accord- 
ingly. 

Judging from the amount of mail this magazine has re- 
ceived concerning both "getting the graphics to work on 
the MX-80" and "getting the necessary ASCII codes greater 
than 159 out of the TI-99/4," | should point out that this 
particular dip switch is the key. If having the graphics char- 
acter-set immediately available (without having to open the 
case) is more important than typing in a few extra charac- 
ters (.DA=8) in each OPEN and LIST command, then set 
SW1-2 to the OFF position. This sets the printer for recog- 
nizing an 8-bit word length, as opposed to the standard 
(default parameter on the ТІ RS-232 Interface) 7-bit 
length. 

With the top case removed, you also have access to the 
printing head (see dark rectangle in lower left section of 
photograph). Why would anyone other than a service tech- 
nician want access to this? Because when needed (after 
50-100 million characters), the head is designed to be 
removed and replaced by any user—without tools, and 
in less than a minute! And the best part is that a new MX-80 


print head sells for only about $30. Quite obviously, this 
feature can save a lot of expense and down time. 

O.K., so the MX-80 is built with service and reliability in 
mind. But can this smaller-than-a briefcase, 12-pound pack- 
age actually live up to its highly touted reputation for out- 
standing print quality? Although the self-test mode demon- 
strated an extremely sharp 9x9 dot matrix character set and 
some block graphics, "мога processing quality” it definite- 
ly was not. There was only one way to actually find out if 
the printer was capable of demanding text applications: І 
had to connect the MX-80 to a porton my RS-232 interface 
with a male/female DB-25 cable (not included with the 
printer), and throw some of those "software switches" that 
printer manufacturers have been recently building into their 
smart (containing microprocessors) machines. 

If you haven't had the opportunity to work with one of 
these new-generation printers, you're in for a pleasant sur- 
prise. By sending some selected СНЕЗ(...) codes (with 
one- to three- digit numbers inside the parenthesis), you can 
put most of these printers through their paces, and watch 
them expand and condense character sets, over-strike 
individual characters, vary their line spacings, etc. 

The Epson MX-80 proved to be no exception. It was ex- 
tremely сазу to "run it through its gears" and make it do 
what | wanted it to do. And what a set of gears! 80-CPS 
bidirectional printing with logical seeking of shortest lines; 
full 96-character ASCII with lowercase descenders; forms 
handling with adjustable tractors; programmable tabs, line, 
and form feeds; 4 printing modes that control the dot den- 
sity (through minute paper advances and line repeats, shift- 
ing right and double striking, and a combination of the 
two); plus 4 different pitches (5, 10, 8.25, and 16.5 charac- 
ters per inch). And although the normal printing pitch of 
10 CPI allows only a maximum of 80 characters per line, in 
compressed mode you can get a full 132 character line on 
your 82 inch sheet. 

If you have to put your finger on the one feature that 
distinguishes this printer from the rest of the pack, it would 
have to be its superb ''correspondence quality" printing 
when in the multi-strike and multi-pass mode—truly unique 
on a dot matrix printer in this price range. The well-formed 
characters with appropriate lowercase descenders are suita- 
ble for all word-processing applications so long as you're 
not attempting to disguise the printed pages as typewriter - 
written correspondence or documents. It comes close (and 
can probably pass quite a few people without notice), but 
it's definitely not the same as fully-formed characters pro- 
duced by the much more expensive, direct-impression 
daisy or thimble printers. 

The only features that | found conspicuously absent are 
such amenities as proportional spacing, underlining, larger 
buffers (the MX-80 has only one line), friction feed for 
single sheets or roll paper, and switch-selectable options 
outside the case. But keep in mind that every time an engi- 
neering team starts adding options, the price starts to climb. 
So marketing strategy necessitates that each printer manu- 
facturer package as many desirable features as possible for a 
target price. Here, the Epson design and marketing team 
deserves a round of applause: They have created in the 
MX-80 an affordable printer that is capable of holding its 
own with many more expensive machines. It rates quite 
high on my MFPB (More-Features-Per-Buck) scale. aq 


Note: By the time you read this, Epson will have introduced 
the MX-80FT, with friction feed in addition to tractor feed, 
as well as a bit-plot graphics option (in ROM) that can be 
added to existing MX-80s. In the next issue, І will show you 
а non-Epson adapter for adding single-sheet and roll feed to 
the MX-80, and explore bit-plot printer graphics. 


KILL 
SURGES 
LIKE 
LIGHTNING! 


AC power line surges are destructive, can cost you 
money, and can't be prevented. But you can stop 
them from reaching your sensitive electronic equip- 
ment with a Surge Sentry. 

Surge Sentry acts in picoseconds to dissipate up 
to a 1,000,000 W, 100 second surge. Triggers at 
1096 above nominal peak voltage. Works in parallel 
with the power line. Is easy to install for immediate 
protection. No complicated wiring or special tools 
required. 

Several different models to choose from, including 
an OEM version. Call or write today for afree brochure. 


SURGE 
ОДА 


It'll clean up your AC 


RKS 

ENTERPRISES, INC. 
643 South 6th Street, San Jose, CA 95112 
(408) 288-5565 


DEALER INQUIRIES INVITED 
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ake а look at the Coding Table shown here. It hap- 
Т pens to be for the Epson MX-80 printer, but it could, 

however, be for most printers with just a few modifi- 
cations. In cofumn 0, row 0, you'll find the box containing 
the NUL character (00000000) which is given the ASCII 
code O(zero). Continue down the column until BEL. The 
bit pattern for that is 00000111, and gets the ASCII code 7. 
In a similar manner, moving down the columns and across 
the rows from left to right, all the alphanumeric, control, 
and graphic characters get number codes. See if you can 
verify that ASCII 65=A, and produces bit pattern 01000001. 
Notice that the left-most bit in the first 128 characters (the 
first 8 columns) is always a zero, and is not nceded to dis- 
tinguish among any of these characters, The ASCII stan- 
dard is therefore a 7-bit code. 


Now, let's look at the Texas Instruments RS-232 Inter- 
face that attaches to your Т1-99/4. It has a normal default 
mode of 7 bits. This means that it will only send 7 of the 8 
bits to the printer unless you specifically teli it that you 
want 8 bits by tacking on .DA=8 to each of your OPEN or 
LIST statements. For Example: 


OPEN #1:"“RS232.DA=8” 
LIST "RS232/2.BA-9600.DA-8" 


As Jong as you stay below ASCII 128(NUL) you're O.K.; 
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but as soon as you go above, the 8th bit is the only thing 
that differentiates between characters that are exactly 128 
codes numbers apart: All characters above 128 have a 1 for 
the 8th (ieft-most) bit. (Of course, for this particular coding 
table, you won't notice the difference until you go above 
code 159.) For example, find code 161 (in column 10, row 
1) that produces a small solid block positioned in the upper 
left corner of a theoretical 2x3 matrix. 


- 


Compare its bit pattern of 10100001 with that for ASCII 
33 (the exclamation mark) that uses 00100001. The only 
difference is in the left-most bit. There is no way for the 
printer to know that you wanted the graphics character 
(code 161) without receiving (and being configured to re- 
ceive by its proper dip switch setting) the 8th bit; in the 
7-bit default mode, it will always print out the exclamation 
mark (!) whenever the BASIC command PRINT CHR$ (161) 
is invoked. 

So, if you want to access a printer's resident graphics set 
(like the MX-80's) keep in mind that the codes for the 
characters wil] usually reside above ASCII 127. You'll then 
need two things: (1) to make sure the 8th bit is sent, and 
(2) to make sure the printer is configured to recognize it. 
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Programming Printer Graphics 


By W.K. Balthrop 


some printers can be extremely useful. In the business 

world, for example, applications might include the 
production of charts and graphs, the printing of business 
forms, and even the design of a letterhead. 

The following short program demonstrates how DATA 
statements are used to format selected graphics characters 
to produce a letterhead. The DATA statements here are for 
use with the Epson MX-80 printer, but can be easily modi- 
fied to accommodate any printer with similar graphics capa- 
bilities. Keep in mind that this is a "shell" program; you 
can plan the DATA statements to direct the printer to pro- 
duce virtually any design or pattern (within limits of the 
resident block graphics set). The actual graphic design (the 
letterhead) in this example is unimportant; but understand- 
ing how to plan and implement it is crucial. 

DATA statements are read sequentially from left to 
right, using the READ statement. The Epson MX-80 printer 
uses numerical codes 160 to 223 (ASCII 32 to 95 with a 1 
for the 8th bit), to generate graphics characters already de- 
fined within the printer. Each graphics character is made up 
of one to six squares within a 2x3 matrix asindicated below. 


T he special graphics character sets that are built into 


(The numbers within the squares are not important if you 
have a coding table in front of you. They represent a partic- 
ular manufacturer's coding of the matrix print head. For 
example, numerical code 165 would produce the fifth char- 
acter in the set, and would cause wires number 1 and 4 to 
fire; if we want the 21st character, wires 1, 4 and 16 would 
be fired.) 


The key part of the program lies in lines 550-590. This 
controls what will happen when a DATA statement is read. 


If the first DATA cell is a number greater than 100, that 
character will be printed. If the first DATA cell is a number 
greater than O but less than 100, the program will read the 
second DATA cell, and then print it the number of times 
specified in the first DATA cell. For example, if the first 
DATA element is 8, and the next is 160 (a blank space}, the 
computer will print a blank space 8 times. This helps lessen 
the amount of required DATA when it is necessary to ге- 
peat the same character several times, If the first DATA cell 
read is equal to 0, a Carriage Return will be executed. 

Regular text can be printed on the same line with the 
graphics. This is done by inserting a negative number in the 
DATA statement. The value of the negative number desig- 
nates which message is to be printed out. This can also be 
used to change the printer's type style, if your printer has 
that capability. For example, if you want to print a graphics 
pattern on the left, and a printed message on the right, you 
would place the negative number just before the zero that 
causes the Carriage Return. Line 590 controls which message 
gets printed using the statement: 


ON ABS(A) GOSUB ххх,ххх,ххх,ххх,ххх,ххх,ххх 


Every time a character is printed—whether graphics, text, 
or a control character —it should always be followed by a 
semicolon. This will insure that the next printed character 
will be on the same line, until the Carriage Return is exe- 
cuted. The only exception to this is in line 610 where I 
wanted the Carriage Return to be executed. 

The following is an example of DATA and the graphics 
line it creates. This line can be found in the 8th print line of 
the letterhead. 


310 DATA 7,160,3,223,9,160,3,223,3,160,3,223,7, 
160,3,223,-4,0 


7 3 9 3 3 3 7:3 


ГЕ ШШ E 


In this graphics line, І first needed to put seven blank spaces 
between the first character position and the first graphics 
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characters. This was done with the first two DATA cells. 
When the program first READs A, its value is 7. Because 
this value is less than 100 and greater than О, the program 
will READ B, the next DATA cell. The value of B is 160. 
ASCII (160) is a blank character on the MX-80, so the pro- 
gram will now PRINT B (blank), A (7) times. On the next 
cycle the value stored in A will be 3, and the value stored in 
B will be 223. This will cause B (ASCII for a solid 2x3 
block) to be printed 3 times. This process is continued until 
a value less than or equal to zero is encountered. 

If the value in A is a negative number, the program will 
branch off to a subroutine which will PRINT a text message. 
In the above example, the value —4 caused the message 
"FOR USERS OF T1-99/4" to be printed. These subroutines 
are extremely versatile; you can change the type style, print 
a message as | have done, continue the program to do calcu- 
lations, or run program lines. 


Note: To conserve space in the magazine listing, | have used 
many separate DATA statements. All the data necessary for 
one entire print line could have been contained in a single 
DATA statement. You may, in fact, prefer to do it this way, 
since it makes the program a little easier to debug. № 


PROGRAM STRUCTURE FOR LETTERHEAD DESIGN 


Line Nos. 

190-510 Contains DATA formatted to print the 99'er 
Magazine letterhead. 

520 OPENS a line to the RS-232 interface for out- 
put to the printer, 

530 Sets the printer for “Double Strike" mode. 

540 Sets the printer for “Emphasized” mode. 

550 READs the DATA statement and stores the 
result in A. 

560 Tests A; if A is greater than 100, then PRINT 
the character stored in A. 

570 Tests A; if A is greater than 0, and less than 
100, then READ B; Print B, A times, 

580 Tests A; if A is equal to zero, then do a Car- 
riage Return. This marks the end of a line, 

590 A equals a negative number at this point; 
ABS(A) controls the branching of subroutines 
for special tasks e.g., PRINT text. 

610-620 Subroutine to execute the Carriage Return, 

630-640 Subroutine to PRINT the value in A. 

650-690 Subroutine to READ B, and print B, A times, 

700-830 Subroutine to print normal text instead of 
graphics. 

840-860 End-of-print message on the screen; END pro- 
gram. 


TAKE A LOOK... 


We have for you 
a magazine within 
a magazine! 


о DATA 


REM 
REM 
REM 
REM 
REM 
REM 
REM 
REM 
REM 
DATA 
DATA 
DATA 
рата 
рата 
рата 
рата 


TYPI IY gf 2 
+ за 
#8 — 99'ER ах 
ха LETTERHEAD $1 
кз te 
ЗЕЯ 


ВУ М.К. BALTHROP | 
99°ER VERSION 5.81.1 

10, 223,2, 160, 10,223 

160, 223, 221, 0, 2,223, 6, 160,2 

223,2, 160, 2, 223, 6, 160,2, 223 
160, 162, 223, 9 
2.225,6.180,2,225,2,160 
2,225,6,180,2,225,0,2,223 
6,150,2,225,2,160,2,225,6,150,2,22: 
DATA 5, 160, 8, 223, 2,160, 2, 223 Н 
рата 2,160,216,2,223,0, 10, 223,2,140 } 
DATA 10,222,5.160,2.225, 4, 160 ] 
DATA 2,225,2,160 i 
DATA 2,223, 192.222, 167,2,163,0 

рата 7,160,5, 223,97, 160,53, 222, 3,160 

DATA 2,225, 4,160, 2, 223 

DATA 2,160.3, 223,161 

DATA 0,7, 160,35, 223, 9, 160, 5, 225 

DATA 3,160,8,223,2, 160,35, 225, 0 

DATA 7, 160, 5, 225, 9, 160, 5, 223, 3, 160 

DATA 3,223,7,160,3,223,-4,0, 7,160, 3,223 
DATA 9, 160,53, 225, 5, 160, 5, 223, 7, 160, 3, 225 
DATA -5,0,7, 160, 3,225, 9, 160, 3,223, 3, 160 
DATA 8, 223,2,160,5,223,-4,0,-7,0 

DATA 25, 160,183, 180, 182, 181, 160, 192 

DATA 166, 194, 2, 160, 183, 2, 163, 145, 160 
DATA 192, 146,196, 2, 160, 2, 162,211 

DATA 165, 160, 162, 203, 143, 160, 183, 196 
DATA 160, 181,160, 183, 2, 163, 165,0, 25, 140 
181, 162,160, 181, 160, 189, 172, 172, 181 
160,215,208, 210, 181, 160, 189, 2,172 
181, 160,220, 211,208, 176, 160, 192, 218 
208, 160, 181,162,196 

181, 160, 215, 211,209, 180 

рата 0,0,-1,0,-2,0.-3,0,-8 

OPEN #1: "RS252/2. BA=9600, разв" 

PRINT S1:CHR$(27);"G" 

FRINT 81 :СНКФ (27); 


READ A 

IF A>100 THEN 650 
IF A»0 THEN 650 
IF А=0 THEN 610 
ON ABS (A) GOSUB 700, 720, 740, 760, 780, 800, 820,840 
вото 550 

PRINT #1 

GOTO 550 

PRINT #1:CHRS(A); 
GOTO SSO 

READ B 


DATA 
DATA 
DATA 
DATA 


FOR Х=1 TO A 
PRINT 81:CHR$ (В); 
NEXT X 

GOTO 550 


PRINT #1: ТАВ (50) ; "EMERALD VALLEY PUBLISHING со."; 


RETURN 

PRINT #1:TAB(38);"P.0. BOX 5557“; 

RETURN 

PRINT #1:ТАВ (54) ; "EUGENE. OREGON 97405" Н 
RETURN 


PRINT #1:TAB(43);"FOR USERS OF TI-99/4"; 
RETURN 

PRINT #1: TAB(43); “AND OTHER TMS9900-BASED"; 
RETURN 

PRINT #1:ТАВ (43); "PERSONAL COMPUTER SYSTEMS" Н 


RETURN 

PRINT #1: TAB(63)2"TM": 

RETURN 

PRINT “ALL DONE WITH LETTERHEAD” 
CLOSE #1 

END 
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WITH MY NEW 
ComPuTeR, Now Т. 


HAVE МОРЕ TIME 
To ро WHAT T Like 


ВЕЎТ-МАКЕ ў $$ 


А 99’er Business Tutorial Series 


Getting Down 


to 


Business 


By George Struble 


ou do not need to be reminded 
Y that microcomputers are having 

more than a micro impact on busi- 
ness. If you are reading this, it is because 
you would like some of that impact to 
benefit you. In a series of articles, we 
will explore some of those benefits and 
show you how to incorporate them in 
your business or professional work. 
Some articles will be at least partly 
cautionary —written to try to keep you 
out of trouble. On occasion, І will re- 
view a piece of business-oriented soft- 
ware of potential use to you. We'll also 
examine some of your experiences (if 
you'll be kind enough to submit them) 
in developing applications for the 
TI-99/4. But don't expect only success 
stories. After all, failures can be most 
instructive 100... 


Planning Use vs. Integrated Use 

It is important to distinguish between 
two major and very different categories 
of business and professional use of the 
computer, The first І will call planning. 
This category includes a lot of activities 
that are helpful to businesses and pro- 
fessional people. Applications in this 
category tend to be analytical or evalu- 
ative. They need not be done on a reg- 
ular basis, but often can be a dramatic 
help in charting future direction and im- 
proving the profitability of a business. 
Some applications require rather little 
in the way of input data, and are essen- 
tially projections; others analyze what- 
ever body of historical data that might 


George Struble, a professor of computer 
and information science at the University of 
Oregon, is author of Business Information 
Processing with Basic, Addison-Wesley Pub- 
lishing Co., 1980. 


be available, Some common examples 
are the following : 


* Comparisons of ROI (Return On In- 
vestment) for the various options. 

* Interest calculations (e.g., effective 
interest rates on installment loans). 

* Profitability analyses for comparing 
charges and costs of providing various 
services. 

* Lease vs. purchase analyses. 


The second category of use is what І 
call integrated use. This category in- 
cludes a lot of functions that support a 
business on a minute-to-minute or day- 
to-day basis. These are for example : 


Maintenance of inventory records 
Preparation of invoices, orders, ser- 
vice contracts, bills, etc. 

* Accounts payable and accounts re- 
ceivable 

* Maintenance of customer or mailing 
lists 
Payroll records 
General ledger and other accounting 
records. 


The potential benefits to your business 
of applications like these are enormous. 
But then, so are the risks! Before you 
allow your business to become depen- 
dent on a microcomputer (or any other 
computer) and set of computer pro- 
grams, there are a number of steps you 
must take to safeguard it against the 
small and large catastrophes that could 
be (at the least) a major setback for you. 
This is not to discourage you from inte- 
grated uses, but rather, to encourage 


you to be very careful about implement- 
ing them. In our next issue we will rec- 
ommend some steps that should help 
you protect yourself against Murphy’s 
Сам "ІТ anything can go wrong, it will!” 
—as it may apply (and indeed, Aas ap- 
plied—more frequently than most would 
care to admit) to integrated computer 
applications, 

A good place for you to start using 
the power of your microcomputer is in 
planning applications, They don't re- 
quire extensive systems of programs or 
comprehensive detailed business records. 
They don't need to be done at any given 
moment, at peril of disaster to your busi- 
ness, And you don't have to chase down 
some itinerant programmer or software 
house to update your program upon 
change of, say, some federal tax formula 
—again, at peril of disaster. Furthermore, 
you can implement some planning ap- 
plications yourself, without extra soft- 
ware, disk drives, extensive data files, or 
a lot of time. 
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Projections : A Planning Use 

Perhaps you've heard the story of the 
wealthy Indian maharajah who was chal- 
lenged to a chess match by a shrewd 
foreign merchant. The merchant put up 
one hundred gold coins as his part of 
the wager, but only asked for rice if the 
maharajah lost the game—one grain of 
rice on the first square of the chess- 
board, two grains on the second square, 
four on the third, eight on the fourth, 
and so on. The maharajah was amused 
and somewhat skeptical that the mer- 
chant would only ask for so little as a 
few grains of rice, but nevertheless, ac- 
cepted the challenge. Naturally—or there 
would be no point to the story—the 
maharajah lost. And as the prize was be- 
ing paid, the full impact became shock- 
ingly clear: So much rice did not exist 
in the world! And even if it did, the 
immense wealth of the maharajah could 
have only paid for a tiny fraction of 
Шен: 

You аге not often confronted with 
this type of wager. But you do have 
opportunities to evaluate. A computer 
can help you to project events into the 
future, vary the assumptions, and tabu- 
late the projected results. Using a com- 
puter program, you can analyze a much 
more complex situation than you would 
be willing to do with just a pencil, calcu- 
lator, and paper. You can change your 
assumptions and let the computer recal- 
culate and reprint the projections, and 
thus gain much more understanding of 
the consequences of various contingen- 
cies as you play what is essentially a 
game of “What if..." As an extra 
benefit, consider the effect the necessity 
of making clear and explicit assumptions 
usable by the computer may force you 
to think more clearly and objectively 
than you might have done otherwise. 
(І wonder whether baseball clubs would 
pay as much for some of their bench- 
warmers and stars if they evaluated the 
consequences and contingencies objec- 
tively.) 

A Program Outline 

Perhaps the best thing about a pro- 
jection program is that it is not hard to 
write yourself in BASIC. The fundamen- 
tal tool is a two-dimensional array. If 
you thought anything connected with 
arrays was necessarily. complex and 
difficult, please read on. You'll soon dis- 
cover that an array application can bea 
lot easier than you imagined. 

An array is nothing more than a table 
in computer storage; a two-dimensional 
array has rows and columns. We must 
assign meaning to each, and write our 
program to honor those meanings. In a 
projection program, | let each column 
represent a year (or month?). If the 
problem requires, | let the numbers in 
the first column represent initial values, 
investments, or costs; the numbers in 
the last column | use to represent resi- 


dual values, or perhaps totals over all 
26 
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1 
1981 


Rents 
Vacancy loss 
Gross revenue 
Property tax 
Insurance 
Interest 


2 3 4 
1982 1983 1984 


Maintenance 


о o паь ам н 


Management 
Depreciation 
Gross expenses 


юю 
_ о © 


Net income 


Figure 1. Use of a Table for a Rental Projection 


years in the projections. Each row rep- 
resents a significant quantity that we 
want to project over the time span. 


Figure 1 shows a simple projection of 
a rental operation. There are four col- 
umns in the array; they represent 1981, 
1982, 1983, and 1984. Each row repre- 


The best thing about a 
projection program is that it 
is not hard to write yourself 
in BASIC ... you can 
implement some planning 
. . Without extra software, 
disk drives, extensive data 
files, or a lot of time. 


sents a quantity necessary to the projec- 
tion of rental results. The array can be 
declared in BASIC by 


60 DIM T(11,4) 


A Basic program can refer to any num- 
ber in the array: for example, to refer to 
the maintenance expense in 1982 we 
refer to T(7,2). 

The outline of a program is shown in 
Fig. 2. Let us examine each of the steps 
of the outline and show how it would 


. Set initial (1981) values 
2. FOR each additional year 


compute the projected values 
. FOR each row of the table 


PRINT a row of the table 


Figure 2. Outline of a 
Projection Program 


be accomplished in a BASIC program, 
The first step is accomplished simply by 
a bunch of LET statements. If rental 
income for 1981 is projected to be 
$20,000, with a vacancy rate of 5%, 
property tax of $3200, insurance of 
$700, etc., the first several BASIC state- 
ments would be 


1010 LET T(1,1)-20000 
1020 LET T(2,1)=.05*T(1,1) 
1030 LET T(3,)-T(1,1)- T(2,1) 
1040 LET T(4)-3200 

1050 LET T(5,1)-700 


These illustrate several ways of assign- 
ing values : 


* directly as a given number (as in 
statements 1010, 1040, 1050) 

* as a multiple of another number (as 
in statement 1020) 

* assumor difference of other numbers 
(as in statement 1030) 


Your application will make it clear how 
to assign each of your values. 


The second step of the program is 
probably the most complex. The idea is 
to march across the table, usually deriv- 
ing each number from the one to its 
left—that is, the corresponding entry 
for the previous year. However, some 
of these entries, too, will be multiples, 
sums, or differences of other numbers 
in the same column. We can use the 
BASIC statement FOR to good advan- 
tage here; it easily specifies a repetition 
for each year. In our rental example, 
these statements could be : 


2000 FOR J-2 TO 4 
2010 LET T(1,J)=T(1,J—1)*1.08 
2020 LET T(2,J)=,05*T(1,J) 
20:0 LET T(3,)-T(1,J)- T(2,J) 
2040 ТЕТ T(4J)-T(4,J-1)*1.06 
2050 LET T(5,J)=T(5,J—1)*1.10 
2200 NEXT J 


These statements reflect assumptions : 


* Rental income increases at an 8% in- 
flation rate. 


Vacancy continues at 5%. 

© Property taxes increase at only (!) а 
6% inflation rate. 

* Insurance costs increase at a 10% in- 
flation rate. 


If you are not sure how all this works, 
take out your pencil and for J with a 
value of 2, play computer and fill in 
numbers in the table yourself as the 
computer would. 


Note how all the assumptions are 
built into the program; each one can be 
changed at will. You should, in fact, 
change several, and re-RUN the program 
several times in order to see the effect 
of each of your assumptions. This is 
sometimes called sensitivity analysis, 
but don't let big words scare you. 

Also, you may use the full capabili- 
ties of BASIC for any special situations. 
For example, we might project that in 
the third year the property will be an- 
nexed to the city and taxes will go up 
30% instead of 6%. We could replace 
statement 2040 by 


2040 IF J-3 THEN 2047 
2043 ТЕТ Т(4,))-Т(4,2-1)%1.06 
2044 СОТО 2050 

2047 LET T(4,J)-T(4J-1)*1.30 


Also, suppose that in the same year we 
expect to have to put on a new roof 
for $8000; this is a maintenance ex- 
pense, but one in addition to the regular 
budgeted maintenance. And unlike the 
taxes, the extra maintenance does not 
continue into 1984. We may use another 
form of the multiplication here : 


2070 IF 1-5 THEN 2077 
2073 LET T(7,J)=T(7,1)* 
1.08^ (1-1) 

2074 GOTO 2080 
2077 LET T(7,J)=T(7,1)* 


1.084 2+8000 


In the last step we display the table. 
The print-out can be prettied up with 
column headings, a description of each 
row, and other such features. A bare- 
bones approach is sufficient, really, and 
could look like this : 


3000 FOR K-1 TO 11 

3010 PRINT K,T(K, 1), T(K,2), 
T(K,3),T(K,4) 

3020 NEXT К 


This segment prints the four numbers of 
each row of the table on one line, so the 
table appears on paper just the way we 
have been thinking about it; each row of 
numbers is preceded by the row number 
(К), which at least helps you to identify 
and keep track of your output. 


A 


igure 3 gathers these program seg- 
ments into one skeleton. With this as a 
guideline, you should now be able to 
sit down and develop your own useful 
projection programs—applied to sales, 
production, commissions, or whatever 
else you need. 


Contributions or Ideas? 

Please send in your ideas for what 
you like to see in this series. If you have 
a project you are pround of, tell us about 
it; we always like to share good news. If 
you have a project that has run into a 
lot of trouble, write about that too. | 
may have some suggestions for you, or 
at least be able to use your experience 
to help others avoid similar problems. 


10 REM 
20 REM 
30 REM 
60 DIM T(11,4) 
1000 REM STEP 1. 
1010 LET T(1,1)-20000 
1020 LET T(2,1)-.05xXT(1,1) 
1030 LET 
1040 LET 
1050 LET 
1990 


Т4, 1) =5200 
Т (5, 1) =700 
STEP 2. 
3=2 то 4 


LET 
LET 
LET 
LET T(5,J) T(5,J—1281 
NEXT J 

REM STEP 3. 
FOR K=1 TO 11 


T(2,J)72.05£1T(1,J) 


NEXT K 
END 


SKELETON OF A PROJECTION PROGRAM 
ROWS OF T REPRESENT INCOME OR EXPENSE ITEMS 
COLUMNS OF T REPRESENT YEARS 


INITIAL VALUES 


Т (5,1) =T(1,1)-T02, 1) 


PROJECT ТО FUTURE YEARS 
TOG, 9) 27 (1, 5-12 11.08 

тез, Фет (1, 9)-T(2,0) 

TU, J)€T(4,J-1) £1. 06 

210 

PRINT THE RESULTS 


PRINT K,T(K,1),T(K,2),T(Ky3),T(K, 4) 


Figure 3 


If you have developed a piece of busi- 
ness applications software that you 
would like to share with the world (for 
а fee?), please tell me about it; | might 
ike to review it if the software seems to 
be of general usefulness. And above all, 
write if І have made errors... І try hard 
or accuracy, but Murphy’s Law hits 
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Ехіепава 


FOR THE тыла HOME COMPUTER 


tion in the ТІ-99/4 community as the announcement 

(what now seems like an eternity ago) that an Extended 
BASIC would be forthcoming. Well, now that the new pro- 
graming language is about to be gobbled up by hungry 
Home Computer users, the question on everyone's mind is, 
naturally enough, “Was it worth waiting for?” 

For the answer to this, and to help put the new software 
in proper perspective, we first should examine TI's claim 
(in the introduction to the reference manual): "Texas 
Instruments Extended BASIC . . . has the features expected 
from a high level language plus additional features not 
available in many other languages, including those designed 
for use with large, expensive computers." The key words 
here are "expected" and "пог available." Features such as 
DISPLAY AT, ACCEPT AT, PRINT... USING, IMAGE, 
ON ERROR, multiple statement lines, expanded IF-THEN- 
ELSE statements, PEEK, Boolean operators, and assembly 
language subroutine calls are indeed “expected.” Unfortu- 
nately, they were expected in the ordinary TI BASIC, since 
they're standard features of various Microsoft BASICs 
found in other machines. But just as plain, old, ordinary TI 


BASIC has its share of surprises that aren't commonly 
found in other BASICs (e.g., CALL SAY, RESEQUENCE, 
complete EDIT, TRACE, and BREAK utilities, plus its 
marvelously simple character definition and color assign- 
ment facilities), ТІ Extended BASIC too has its own unique 
bag of tricks лог found on other machines. And this bag of 
tricks includes some mighty impressive feats of computing 
magic. 


N othing has caused as much excitement and anticipa- 


But before we get into these extended features, let's ex- 
amine some of the obvious changes from TI-BASIC, First, 
there's the matter of a slight reduction in usable RAM. The 
maximum program size of Extended BASIC is 864 bytes 
smaller than TI BASIC. Although this represents only about 
a 6% reduction, any reduction in user memory is significant 
if it prevents certain applications from being RUN. And, in 
fact, as little as 500 bytes is frequently the critical amount 
of extra memory needed. (Witness the several programs in 
this issue that cannot be loaded or RUN with the disk con- 
troller's power turned on—even with the CALL FILES(1) 
command that frees all but about 500 bytes for the disk 
system.) So programmers without the 32K RAM expansion, 
should try wherever possible to make up the loss with 
Extended BASIC's built-in memory saving features: multi- 
ple statement lines (with more allowable characters per 
line), expanded IF-THEN-ELSE statements, multiple varia- 
ble assignments, trailer comments that immediately follow 
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HOW E-X-T-E-N-D-E-D 


IS 


IS EXTENDED BASIC ? 


By Gary M. Kaplan 


statements (instead of separate REMs), repetition of strings 
with the RPT$ function, and the use of MIN and MAX 
functions. 

The loss of user-definable characters in the character sets 
15 and 16 is another departure from the TI BASIC standard. 
These custom characters are no longer available to pro- 
grammers since the memory area is needed to keep track of 
sprites. Therefore, a ТІ BASIC program that doesn't use 
these character sets is supposed to RUN in Extended BASIC 
[Watch the next issue for an analysis of what /5 and isn’t 
interchangeable.] in most circumstances—unless, of course, 
you've done something that will obviously cause trouble 
such as accidentally using а ТІ Extended BASIC keyword as 
a variable in your TI BASIC program (e.g., DIGIT, ERASE, 
т IMAGE, MERGE, MAX, MIN, SIZE, WARNING, 
еіс. 


Now, let's take a peek (по pun intended) into the "Бад 
of tricks" | mentioned earlier. We'll cover only the highlights 
in this article; subsequent articles will take an in-depth look 
at the different features, and show you powerful and 
unique ways of using them. 

A good place to start is with Extended BASIC's exciting 
new graphics capabilities. Nine new subprograms (plus 2 re- 
designed ones) provide the ability to create and thoroughly 
control the shape, color, and motion of smoothly moving, 
high-resolution graphics. These are the true sprites—graphics 
that can be displayed and moved at any of 49, 52 positions 

192 rows x 256 columns) rather than the /68 positions 
24 rowsx32 columns) CALLed by the VCHAR and 
HCHAR statements of TI BASIC. But that's only the begin- 
ning. Sprites can be set in motion with simple X and Y 
velocity components, and will continue their motion 
without further program control; they can grow and shrink 
at will, be relocated or “hidden”, and even pass over and 
blot out fixed objects and other sprites to give the illusion 
of depth and 3-D animation. [This is a function of the 
three-dozen stacked image planes of the Home Computer's 
video display processor chip—a unique graphics display that 
will be explained more fully in the next issue.] 

Although games aficionados and educators have every 
right to be overjoyed with the new sprites capability, ТІ-99/4 
users who are more іпїегеѕ^ in business, scientific and 
professional applications “ | бе drawn to other Extended 


BASIC features. First on + г list is the impressive subpro- 
gram capability. Several options exist for communicating 
values (and entire arrays) between main and subprograms, 
There's also built-in protection to prevent a subprogram's 
local variables from affecting the main variables. Additional- 
ly, commonly used subprograms may be SAVEd on a sepa- 


rate disk, and later MERGEd. This will allow programmers 
to build up an library of “universal” subprograms that can 
be called upon to supply the appropriate modules for new 
programming tasks—without time-consuming re-coding and 
debugging. 

If this new subprogram flexibility is not enough for your 
most demanding tasks, how about “program chaining” 
—where one program can load and RUN another program 
from a disk. This means that multi-part programs of almost 
unlimited size can now RUN on the ТІ-99/4 by breaking 
them into pieces and letting each segment RUN the next. 
And at any point in this chain, a "menu" may be inserted, 
allowing the user to choose with a single keystroke the 
particular program to be RUN. Imagine the possibilities! 

Those of you with a speech synthesizer, or thinking of 
purchasing one, will be happy to learn that Extended BASIC 
includes a speech editor. You will no longer need the sepa- 
rate Command Module (with a retail price of about $45). 
What's more, with the combination of CALL SPGET, the 
capability of subroutine MERGEs, and the data for the 
code patterns (that TI supplies in the appendix of the refer- 
ence manual), you can now easily add the suffixes ING, S, 
and ED to the roots of words in the resident vocabulary. 
And if ТІ ever supplies users with their master file of coded 
Speech patterns and rules for combining them, it would be 
possible to create your own new words. As of now, they 
only provide the cryptic, "Because making new words is a 
complex process, it is not discussed in this manual." [See 
the speech synthesis contest in the next issue, for a glimpse 
of what these code patterns look like—Ed.] 

Incidentally, this cabability of having the computer say 
what you want it to say rather than being limited to a fixed 
vocabulary will, in fact, be implemented through a related 
approach. I’m referring to the “text-to-speech” capability 
of the forthcoming Terminal Emulator 11 Command Module 
which is programmable in ТІ BASIC. Since only one Com- 
mand Module at a time can be attached to the TI-99/4, 
text-to-speech [see related article in this issue —Ed.} cannot 
be used with the Extended BAS/C Command Module. | 
think it's safe to say, however, that we can expect to see TI 
solve this problem in the near future. 


The final two features I’m going to cover in this overview 
provide a fair degree of software protection and open the 
door to additional language capabilities. Consequently, these 
are the particular features that may have the most profound 
impact on the entire TI-99/4 community—ultimately deter- 
mining the quality and quantity of most of the commercial 
software produced for this machine. 

Extended BASIC programs can be SAVEd in a PRO- 
TECTed f "т to guard against software piracy. This irre- 
versible feature only allows a program to be RUN or loaded 
into memory with an OLD command. A program thus 
PROTECTed cannot be LISTed, EDITed, or SAVEd. If the 
program was originally SAVEd and PROTECTed on a disk, 
you still must use the protect feature of the Disk Manager 
Command Module to completely “lock up" the software by 
preventing it from being copied as well. 

Extended BASIC has the capability to CALL and RUN 
assembly language programs if the 32K RAM expansion 
peripheral is attached to the computer. Since assembly lan- 
guage has a much faster execution speed than BASIC, many 
applications programs that are unfeasible to write in either 
TI BASIC or TI Extended BASIC (and Extended BASIC is 
not significantly faster than its predecessor) can now be 
written in TMS9900 авзегг “іу language, LOADed into the 
expansion memory perjphe | ‘апа RUN on a TI-99/4. This 
paves the way for some fa 'у sophisticated applications 
programs that now can be targeted for the Т1-99/4 users. 
[See related assembly language article in this issue.] 

Even though а T1-99/4 with Extended BASIC and the 
memory expansion can CALL and RUN assembly language 
programs and subroutines, it present/y cannot be used to 


write them. [Except for its “P-coded” version equipped 
with the UCSD Pascal Development System as explained in 
this issue's related articles on third-party software develop- 
ment, and UCSD Pascal/Version 4.0] Alternately, it would 
have been helpful if TI had given Extended BASIC users the 
capability to POKE values into memory locations, but this 
feature was not implemented. Nevertheless, the door is now 
opened for a TMS9900 assembler (which TI will soon be 
marketing) that can be loaded into the expansion 32K 
RAM peripheral, and called up through Extended BASIC. 
Besides the obvious use of an assembler—being able to write 
programs or subroutines in assembly language—it does, in 
fact open up other exciting possibilities: “Моге exotic" 
languages can be specially written in TMS9900 assembly 
for ТІ-99/4 implementations. (FORTH and LISP hackers 
take note...) 

The bottom line is more software tools for developers, 
and more economic incentive for them to produce valuable 
programs that can be protected against most piracy. This 
means that the Т 1-99/4 user community will be seeing a lot 
more useful software enter the market. Being able to run 
this software should more than justify the $100(retai!) 
price for this filled-to-capacity 36Kbyte 7/ Extended BASIC 
Command Module with accompanying 224-page reference 
manual. Therefore, the answer to the title's rhetorical ques- 
tion, “How Extended Is Extended BASIC?” is apparently, 
“Extended enough...” 


Get Ready Sprites — 


Here І Come... 


Inventory, Order Entry, 
Sales, & Mailing List 
For Your TI-99/4 


Interactive Programming 
Allows Maximum Flexibility for Customizing 
the Software to Your Specifie Needs, 


Each program available separately: 
e Inventory $44.95 cassette; $49.95 disk 


* Order Entry " " 
е Sales " " 
* Mailing List " - 


Interactive packages — disk-based only: 


е Inventory - Sales $89.95 

Ф Inventory - Order Entry 89.95 

е Order Entry - Mailing List 89.95 
All 4 programs $189.95 


(FREE /ibrary storage case included) 
Add $2.50 for postage/handling. 
California orders, add 696 tax. 


To order, or for more information: 


Paul Yates Computer Services 
4037 Johnson Drive 
Oceanside, CA 92054 


Tel. (714)-758-1633 
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TEXT-TO-SPEECH 
ON THE HOME COMPUTER 


By Gary M. Kaplan 


о ahead—shout something at your 
( home computer... but don’t be 

surprised if it answers you back! 
Welcome to the exciting world of talk- 
ing computers—a world in which synthe- 
tic speech will very soon cease being a 
novelty, and will instead become instru- 
mental in the everyday interactions be- 
tween humans and machines. 

If you have a Texas Instruments 
Home Computer, you’re one jump 
ahead of everyone else in taking advan- 
tage of this revolutionary communica- 
tions tool. All you need additionally is 
the Speech Synthesizer peripheral, and 
the plug-in Terminal Emulator 11 Com- 
mand Module. Text that you type on 
the console keyboard will be converted 
to synthetic speech, and “spoken” 
through your TV set or monitor, There's 
no fixed vocabulary to constrain you, 
and personal phrases can be called up 
under program control through the TI 
BASIC computer language. 

But this is only the beginning .. . If 
you connect T 1'5 RS-232 interface and а 
modem to this configuration, you can 
have access (through your telephone) to 
the electronic mail, database, entertain- 
ment, and computing facilities of The 
SOURCE and its soon-to-be-available 
offspring, TEXNET.* The TEXNET 
service will allow Т 1-99/4 users to access 
all the menu selections from its parent 
information utility (plus some addition- 
al) with the enhancements of text-to- 
speech, sound effects, music, and color 
graphics! Imagine a weather report with 
a color graphic representation of a bright 
sun being blotted out by ominous look- 
ing rain clouds, while "Stormy Weather " 
is being played in the background, and 
the temperature, wind, humidity and 
other vital statistics are flashed on the 
Screen and recited to you by your 
* Service Mark of Texas Instruments 
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speech synthesizer—an exciting prospect 
at the least. 


Linear Predictive Coding (LPC) 


When Texas Instruments made the 
first single-chip speech synthesizer in 
1978, its original application was in 
their Speak & Spell learning aid. The 
chip, a TMS 5100, is essentially an elec- 
tronic model of the human vocal tract 
(a mathematical model implemented as 
a filter network) that reproduces speech 
through a technique known as Linear 
Predictive Coding (LPC). There have 
been other approaches to speech storage 
—methods employing digitalized speech 
and pulse-coded modulation codecs—but 
these result in data rates that are too 
high (64,000-100,000 bits per second). 
And the higher the data rate, the fewer 
words of speech the available memory 
can hold. 

The value of TI's LPC technique is its 
modest memory requirement; it pro- 
vides speech quality nearly comparable 
to these other methods, at a much lower 
data rate (1,200 bits per second). For 
example, a speech reproduction of the 
words "Texas Instruments" requires ap- 
proximately 90 times as many bits using 
digitized speech techniques as it requires 
with LPC. 

What is the secret to LPC's economy 
of storage? The "Р" in the middle that 
stands for "Predictive." Here's how it 
works: A speech waveform is originally 
sampled and encoded. This data is used 
to calculate the coefficients of the linear 
equations of the digital filter network 
that will control the "shape" of this 
synthetic vocal tract. When excitation 
noise (a chirp function and white noise 
generator) is applied to this filter net- 
work, the circuitry produces a simula- 


tion of the resonant effects of the 
mouth and nasal cavities. 


Allophones 


This is fine if a user doesn't mind be- 
ing confined to a pre-stored vocabulary. 
It is, however, under-utilizing the syn- 
thesizer's capability to produce any 
spoken word on demand as long as it 
has the appropriate input data. This is 
where ТІ% recently unveiled allophone 
stringing technique comes into play. TI 
inguists have chosen 128 separate 
sounds called “allophones” that сап be 
linked together to sound out any word 
in the English language. Allophones are 
variations of a particular “рһопете” 
the smallest unit of speech that can dis- 
tinguish one utterance from another) 
that are modified by the environment in 
which they occur. For example, the as- 
pirated (followed by a puff of air) “р” 
in “ріп” and the non-aspirated "р" in 
"spin" are allophones of the phoneme 


"p." These allophones represent the 
sound more accurately than the 
phoneme. 


A total of 128 allophonesare grouped 
in a library occupying only 3 kilobytes 
of memory storage. Each allophone is 
identified with a numerical code (indi- 
cating the parameters for setting the 
filter characteristics in the LPC synthe- 
sizer). When a word is entered into the 
computer, its ASCI] (American Stan- 
dard Code for Information Interchange) 
representation is identified; the com- 
puter's CPU then searches through a set 
of rules (contained in 7 kilobytes of 
memory storage) to pick out the appro- 
priate allophones and string them to- 
gether in the proper sequence (“сопса(- 
enation") to represent the keyed-in 
words. 

The rules (about 650 presently) over- 


T1-99/4 Console 


come most of the many pronunciation 
exceptions and irregularities in the Eng- 
lish language (able to correctly select 
both phonemes and allophones over 
909; of the time). However, speech 
scientists have found it impossible to a- 
chieve 100% accuracy in a text-to-speech 
system of this type since there are too 
many silent letters and other incongrui- 
ties that humans perceive, but that the 
computer cannot discern. To get around 
this problem, some words must be typed 
into the computer phonetically or en- 
tered allophone-by-allophone. 

If this was all the text-to-speech soft- 
ware did, the quality of the speech 
would sound monotonous and unnatural. 
ТІ therefore provides its software with 
the ability to produce more lifelike in- 
flection: users can add stresses to cer- 
tain syllables, and required pitch patterns 
to particular points in a sentence. Ques- 
tions then sound like questions, and 
commands like commands! 


Text-to-Speech with the ТІ-99/4 


The chip used in the Speech Synthe- 
sizer peripheral that attaches to the 
ТІ-99/4 is a TMS 5200—a second gener- 
ation of the TMS 5100 (used in the 
Speak & Spell). It has the following 
added features : (1) "Speak External" 


Control (4 Bits) 


TMS9900 CPU 
Plus 16-Bit-To-8-Bit 
Data Bus Converter 


Terminal Emulator II 


Memory Data Bus (8 Bits) 


Speech 
Synthesizer 


Text 
Input 


Text-To- 
Allophone 
Rules (7K) 


Allophone-To- 
Synthesizer 
Data 


Allophone 
Library 
(3K) 


Command Module 


input which allows the chip to accept 
speech data from a source other than a 
Speech ROM (read-only memory), (2) 
an internal buffer to store chunks of da- 
ta (freeing the CPU for other tasks), and 
(3) a memory data bus allowing it to 
work with any standard 8-bit micropro- 


From Keyboard or Via 
Telecommunications Network, 


MASS Synthetic 


Speech 
“Ча, 


Speech Synthesis 


Speech Construction 


cessor. [The 16-bit data bus of the 
TMS9900 microprocessor is converted 
to 8 bits for use with all ТІ-99/4 periph- 
erals.] 

The text-to-speech produced by this 
configuration is a two part process: (1) 
the speech construction phase in which 
letters are translated into a digital repre- 
sentation of component sounds and are 
concatenated (strung together), and (2) 
the speech synthesis phase in which the 
LPC circuitry "voices" the spoken 
words through a simulation of the 
mouth and nasal cavities. As seen in the 
accompanying diagram, speech con- 


struction is handed by the software 
resident in the Terminal Emulator 11 
Command Module, and speech synthesis 
by the TMS 5200 chip within the sepa- 
rate speech peripheral. @ 


Notice the reactions of people hearing text-to-speech for the first time 
(introduced at the January Consumer Electronics Show). 
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INTRODUCTION ТО TI BASIC 


By D. Inman, В. Zamora, and В. Albrecht. 
This comprehensive work, written by three of the fore- 
most microcomputing programming experts in the coun- 
try, will teach you all about computers and BASIC for use 
with the Texas Instruments Home Computer. Even if 
you've never worked with a computer, you can now teach 
yourself how to use, program and enjoy the TI Home 
Computer with this entertaining, and easy-to-read work 
The authors have carefully constructed this introduction 
so that you wil! soon be writing BASIC programs and ex- 
ploiting all of the excellent features of the Ti machines. Its 
14 chapters and Appendices cover all of the essential pro- 
gramming statements and machine features 

CONTENTS: Gateway to Adventure. Do It Now: Sound 
and Color Graphics. Simple Programming. Looping 
Sound and Color. More Programming Power. Beginning 
Simulation. More Program Control Statements. Using 
Data Files. One Dimensional Arrays. Two Dimensions and 
Beyond. Color, Graphics, Sound, and Animation. More 
Strings. Editing. Subroutines and Your Personal Library. 


paper, $10.95 
1980, 320 pages. 7'/ x P/a- 


PROGRAMMING BASIC WITH THE 

TI HOME COMPUTER 

By Herbert D. Peckham, 

A tutorial guide that helps you learn ТІ BASIC in a 
friendly, relaxed manner. It goes beyond Beginner's 
BASIC furnished with the ТІ-99/4, and introduces 
the full range of TI BASIC features including color 
graphics and sound. Its 11 chapters are written in a 
complete-the-blanks, programmed instruction format. 


paper, $10.95 
1979, 306 pages, 6 x 9 
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BASIC COMPUTER PROGRAMS 
FOR THE HOME 


By Charles D. Sternberg. 
The only book named in an update article in the Personal 
Business section of Business Week (June 23, 1980)! 

An invaluable book at a great price, it contains over 75 
practical home application programs that will be helpful 
to the novice or experienced owner in increasing the use- 
fulness of any home computer. Each program is docu- 
mented with a description of its functions and operation, 
alisting in BASIC, a symbol table, sample data, and one or 
more samples. Programs included are: Home Financial 
Programs; Automobile Related Programs; Kitchen Help- 
mates; Scheduling Programs for Home Use; List Pro- 
grams for Every Purpose; Miscellaneous Programs for the 
Ноте: Tutorial Programs for Home Use; Conversion Pro- 
gram; and Hobbyist's Diaries. 


paper, $9.95 
1979, 336 pages, 7'^ x P/a 


GAME PLAYING WITH BASIC 


By Donald D. Spencer. Abacus Cornputer Corporation. 

Enjoy the challenge of competition with your computer. 
Amuse yourself with such games and puzzles as 3-D Tic- 
Тас-Тое. Nim, Roulette, Magic Squares, the 15 Puzzle, 
Baccarat, Knight's Magic Tour. and many others. The 
writing is nontechnical. allowing almost anyone to under- 
stand computerized game playing. The book includes the 
rules of each game. how each game works, illustrative 
flowcharts. diagrams. and the output produced by each 
program. The last chapter contains 26 games for reader 
solution. 


paper, $9.55 
1977. 176 pages. 6 x 9, illus. 
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BASIC COMPUTER PROGRAMS 
IN SCIENCE AND ENGINEERING 


By Jules Н. Gilder. 

Save time and money with this collection of 114 ready-to- 
run BASIC programs for the hobbyist and engineer. There 
are programs to do such statistical operations as means, 
standard deviation averages, curve-fitting, and interpola- 
tion. There are programs that design antennas, filters, at- 
tenuators, matching networks, plotting, and. histogram 
programs. There is even a justified typing program that 
can be used in typesetting. All programs in the book have 
been tested and are fairly universal; so you should have 
no difficulty running them on your system. You won't find 
anywhere a more comprehensive collection of usable, 
ready-to-run BASIC programs! 

See also software section 


BASIC COMPUTER PROGRAMS FOR 
BUSINESS: VOL. 1 


By Charles D. Sternberg. 

A must for small businesses utilizing micros as well as for 
entrepreneurs, these two volumes provide a wealth of 
practica! business applications. Each program is docu- 
mented with a description of its functions and operation, 
a listing in BASIC, a symbol table, sample data, and one or 
more samples. 

Volume 1 contains over 35 programs covering: budg- 
ets. depreciation, cash flow, property comparisons, ac- 
counts payable. order entry, warehouse locations, inven- 
tory turnover analysis, job routing, resource allocation, 
production scheduling. etc 


volume 1, paper, $10.95 (t) 


paper, $9.95 1980, 384 pages, 7 x 9У, 
1980, 160 pages, 6 x 9. illus. | 


PRACTICAL BASIC PROGRAMS 

Edited by Lon Poole 

Here is a new collection of 40 programs you can easily key in and use 
on most microcomputers. Each program does something useful. Practi- | 


thc cal BASIC Programs is especially useful in small business applications. It 1 
Ке З solves problems іп finance, management decision, mathematics and ] 
Р з и statistics. It requires по prior programming knowledge. Each program is | 


thoroughly documented. The book contains sample runs, practical 

problems, BASIC source listings, and an easy to follow narrative to help 

you realize the potential uses of each program. This book is a valuable 

- reference for anyone who needs а wide range of useful programs: income 
averaging, present value of a tax shield, lease/buy decision, financial 
statement ratio analysis, checkbook reconciliation, home budgeting, 
^ nonlinear breakeven analysis, Program Evaluation and Review Technique 
i b (PERT), statistics, data forecasting divergence, musical transposition, 
Bayesian decision analysis, etc. paper $15.99 
1980, 200 pages, 8% x 11 


Use the order card in the back of this magazine, or itemize your order on a separate piece of paper and mail to: 
99'er Magazine/Book Dept., 2715 Terrace View Drive, Eugene, OR 97405. Be sure to include check or 
detailed credit card information. No. C.O.D. orders accepted. Add $1.50 postage & handling for 


1 book, $2.00 for 2 books, or $2.50 for 3 or more books. Please allow 4-6 weeks for delivery. 
If there is a question regarding your order please write to Customer Service at the above address. 
PRICES SUBJECT TO CHANGE WITHOUT NOTICE. 
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HOME COMPUTERS CAN MAKE YOU RICH 

By Joe Weisbecker. 

Here's а valuable text for every home computer owner 
and nonowner interested in spare-time income opportun- 


ities. You'll be introduced to the microcomputer industry, 


and the types of people involved in it. You'll find out how 
to learn more about this new industry. Discussed are 
basic principles of making money, freelance writing, pro- 
gramming, consulting, inventing, computer-made prod- 
ucts, investing, and much more. The goal of this book is 
to stimulate computer designers and microcomputef 
companies to direct more effort to the home computer 
market. 

CONTENTS: The Microcomputer Industry. What You 
Need to Know About Making Money. Resources You Can 
Use. Choosing Your Hardware. Writing for Money. Creat- 
ing and Selling Programs. Services for Sale. Use Your 
Imagination. Invent Your Way to Success. Making Your 
Money Grow. Working at Home. 


5177-8, paper, $6.50 
1980, 128 pages, 6x 9 


BEAT THE ODDS: MICROCOMPUTER 
SIMULATIONS OF CASINO GAMES 


By Hans Sagan. 
Here's an extremely useful programming guide that pro- 
vides realistic simulations of five popular Casino games: 
Trente-et-Quarante (Thirty and Forty), Roulette, Chemin- 
de-Fer. Craps, and Blackjack. Each of the five chapters 
has the same structure. It begins with a computer run, 
displaying facets of the programs, followed by an expla- 
nation of the objectives and the physical execution of the 
game. Acceptable bets and how to place them are dis- 
cussed and systems and/or strategies laid out. Finally, the 
computer program is developed and various modifica- 
tions of the program are detailed 

All programs are written in BASIC and heavily REM'd 
for readability and conversion. A.comprehensive bibliog- 
raphy, a glossary of French gambling terms and phrases, 
and hints on the discrepancies between BASIC dialects 
are included, as well as a summary of maxims of probabil- 
ity theory. 


5181-6, paper, $7.95) 
1980, 128 pages, 6x 9 


MINDSTORMS: CHILDREN, COMPUTERS TEACH 
AND POWERFUL IDEAS 


By Seymour Papart 

The definitive work on the philosophy behind 

LOGO. Excerpted in the May/June issue of this 

magazine. hardcover, $12.95 
1980, 230 pages, 6x 9 


TEACH YOUR BABY MATH 

By Glenn Doman 

The book upon which the 7/пу Math / program 

(in the May/June issue of this magazine) is 

based. hardcover, $8.95 
1969, 110 pages, 6x 9 
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рая 


Beginner's 

Guide 

for the UCSD 
Pascal 

System 


їж Kenneth L Пас 


INTRODUCTION TO PASCAL 

(INCLUDING UCSD PASCAL) 

By Rodnay Zaks 

This is the first book on Pascal that can be used by 


BEGINNER’S GUIDE FOR THE 

UCSD PASCAL SYSTEM 

By Kenneth Bowles 

This highly informative book is written by the 


originator of the UCSD Pascal System. It is designed 
as an orientation guide for learning to use the UCSD 
Pascal System, and features tutorial examples of pro- 
gramming tasks in the form of self-study quiz pro- 
grams. Once familiar with the system you will find 
the guide an invaluable reference tool for creating 
advanced applications. paper $11.95 

1980, 204 pages, 6 x 9 


AN INTRODUCTION TO. 
Microcomputers 


persons who have never programmed before, but 
more generally it is a simple and comprehensive intro- 
duction to standard and UCSD Pascal for anyone— 
beginner to experienced programmer—who wants to 
learn the language rapidly. The logical progression 
and graduated exercises—designed to provide practice 
as well as test skill and comprehension—enable the 
reader to begin writing simple programs almost im- 
mediately, This book presents all concepts and tech- 
niques in a clear and simple style, making it accessible 
to beginners and useful to experienced programmers, 
All Pascal features are covered in detail, from basic 
definitions to complex data structures. An extensive 
appendix section presents a listing of all symbols, 
keywoods and rules of syntax for programming in 
Pascal, providing a concise summary and important 
reference tool. paper $14.95 


Adam Osborne 


AN INTRODUCTION TO MICROCOMPUTERS — 
VOLUME O: THE BEGINNER’S BOOK 

By Adam Osborne 

Here’s the book to start with if you know nothing 
about microcomputers but wish to learn about them. 
With the help of numerous illustrations and a 
wonderfully lighthearted text, Vo/ume O will help 
give you a sound understanding of the basics of 
microcomputing. You'll learn about the microcom- 
puter’s construction, terminology, internal logic, and 


AN INTRODUCTION TO MICROCOMPUTERS — 
VOLUME 1 — BASIC CONCEPTS 

By Adam Osborne 

Using concepts that are common to all microprocessor 
systems, Vo/ume 7 develops a detailed picture of what 
a microcomputer can do, how it does what it does, 
and how the capabilities of microcomputers can best 
be applied. Basic Concepts presents the fundamental 
logic framework upon which microcomputer systems 
are built, so that the reader can evaluate the applic- 
ability of microcomputers to any practical problem. 
This new revised edition incorporates all recent micro- 


application. If you have plans to program microcom- 
puters, ог if you must make decisions related to 
microcomputer applications, Тре Beginner's Book 
will provide the terminology and general concepts 
you'll need. This volume also provides an excellent 
background for the beginner wanting to go on to An 
Introduction to Microcomputers: Volume 1 — Basic 
Concepts. paper, $7.95 

1979, 240 pages, 5x 8 


processor developments. Concepts are discussed in 
terms of modern hardware configurations, and ex- 
amples of common applications are drawn from to- 
day's most popular devices. For example, the logic 
instructions and programming concepts of the new 
16-bit microprocessors are discussed in detail, and 
current logic distribution configurations are used 
throughout the text with numerous illustrations and 
examples, Programming mnemonics conform to the 
newly proposed IEEE standard. This is the first book 
in print to use them. paper, $12.99 

1980, 320 pages, 7 x 9 
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Ву W. К. Balthrop 


Let me tell you the story about а тап named Jed, 
A poor mountaineer--barely kept his family fed, 
And then one day while shootin’ at some food, 
Up from the ground came a'bubblin' crude... 
Oil, that is— "Black Со”... "Texas Tea." 


The Beverly Hillbillies 
(A popular ТУ show of the late 1950s) 


late 1950s, one of the American public's favorite 

"get-rich-quick" fantasies has been to strike oil in 
one’s own backyard ... and like Jed, become an “instant 
millionaire." The last decade's oil price hikes, along with 
the recent heavy promotion of oil and gas lotteries have un- 
doubtedly added to the mystique and lure of "'wildcatting" 
—prospecting for oil in an untapped or questionable area. 
And Hollywood movies haven't exactly portrayed wildcat- 
ters as calm, level-headed, conservative businessmen who 
are out to make a reasonable profit. Rather, we're shown 
images of a lusty, brawling gambling lot who are time and 
again willing to risk all they have (and can borrow!) on a 
crapshoot—little more than a hunch that the next well 
sunk won't come up dry... 

What is it rea//y that brings success and wealth in this 
romantic endeavor? Luck? Courage? Good business sense? 
Or perhaps, a combination of all three? Well, now you can 
find out for yourself—in the comfort of your own home, 
with nothing more to risk than the price of a new simula- 
tion program for your Home Computer. 

Wildcatting, from Image Computer Products, is a game 
of strategy for up to four players. In no time at all, any of 
the players may, in fact, "strike it rich," or "come up dry" 
once too often—joining the ranks of history's defeated 
gamblers... 


F ver since the debut of The Beverly Hillbillies in the 


Operation 


To play Wildcatting, you'll need a color TV or color 
monitor connected to your TI-99/4. Unlike many other 
computer "business simulations" that display only text or 
simple graphs, this program includes a simulation of an oil 
field as a three-dimensional model, with colors representing 
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the height. Each time the program is run, a different map is 
constructed and stored in the computer's memory. Drilling 
costs, the predicted probability of striking oil, and the 
amount of oil a well produces are all calculated for each 
location. 

Each player takes a turn (representing a week) picking a 
location, taking a geological survey, and deciding whether 
or not to invest money drilling for oil. The survey reveals 
the probability of astrike, drilling cost per meter, and week- 
ly taxes. If drilling is attempted, the drilling cost, depth of 
well, and player's net worth are displayed every 50 meters. 
A cross-sectional view of the actual drilling progress is also 
displayed on the screen and controlled by depressing the 
space bar. A player can stop drilling at any time when he or 
she feels that the cost is getting too expensive; The well 
may then be sold for а Іо55. Any of the player's other wells 
that start to dry up (and produce less income than the week- 
ly taxes) may also be sold at that time. After each player's 
turn, a color position marker is left on the oil field. These 
squares indicate the probability of striking oil at that loca- 
tion. By studying the color patterns that begin to emerge 
after a few turns, it becomes possible to make predictions 
on where the exact center of the oil field (with 10096 prob- 
ability of striking oil) will be. Players have ten weeks to 
either amass their fortune or go broke. 


Performance and Engrossment 


Although the economics are purely fictional, the costs 
for drilling and the outputs per week providea well-balanced 
and realistic game. Simple, straightforward instructions 
make the game easy to learn. The controlling keys are well 
documented with screen instructions: A player makes deci- 
sions with a simple “У” or “М”, selects wells to be sold by 
using the up and down arrow keys, and accomplishes all 
other functions with the space bar. Despite the game's sim- 
ple structure and ease of play, it is nevertheless challenging 
and difficult to win. Even in an area with a high probability 
of striking oil, the well may, in fact, be dry! 

The only minor operational fault І could find is display- 
dependent. It is, however, not the direct fault of the soft- 
ware developer. At the time the game was originally de- 
signed, the TI-99/4 was sold together with the color video 


monitor; the RF modulator (for hooking up the computer 
to a regular TV set) wasn’t available. When used as a com- 
puter display, some TVs can’t fit all 32 columns on the 
screen, and wind up chopping off one or two columns from 
each edge. So if a programmer is working only with the 
monitor and plans the display to utilize the very outer 
columns for important information, it can bea problem for 
users with certain models of TVs. Since in Wi/dcatting you 
use a blinking arrow on the extreme left to indicate the well 
you decide to sell, it's quite possible that on certain TVs 
you won't be able to see this symbol, and might accidental- 
ly зе! the wrong well! Fortunately, the map itself is not 
affected. 


[Since most Т 1-99/45 are now being sold without monitors, 
99'er Magazine suggests that all software developers take 
into account the wide range in performance of different 
TV e and design their program screen displays according- 
ly—Ed. 


If Wildcatting merely had the features that Гуе detailed 
so far, І would have to classify it as “ап interesting game 
that performs well, and iseasy to learn and play." | wouldn't 
necessarily feel that it was particularly engrossing or absorb- 
ing—in the sense of losing sleep over . . . or forgetting to eat. 
But the people at Image Computer Products did, in fact, 
put in one additional feature that caused the program to 
jump up a few notches on my “engrossment scale": Each 
player gets a chance to actually “handle the drill" (controlled 
by depressing the space bar), hear the whirring and grinding 
noise of the bit, and watch in fascination as the shaft plunges 
deeper and deeper into the earth. When you finally make a 
strike, the abrupt audio and visual effects that simulate the 


“gusher” practically jolt you out of your seat (at least it 
nearly did the first time ...). It's quite a realistic effect 
—one that will keep you anxiously awaiting for your turn 
to “handle the drill” to come around again. 


Documentation and Packaging 


The people at Image have done well in making sure that 
the product lives up to their company name. The cassette 
(within its protective plastic case) is packaged in an attrac- 
tive, 4-color, book-size box; it can conveniently be stored in 
a bookshelf next to your Tl Command Modules. The 6-page 
typeset instruction booklet explains every step of play in 
well defined, easily-referred-to sections—making it quick 
and easy to look up some forgotten detail. The one minor 
complaint І have concerns the design of the storage box. Га 
like to see a latch on the rear panel of the cardboard box to 
prevent the cassette and case from accidentally falling out 
when the box is pulled from the shelf or carried. 

АН in all, | feel that Wi/dcatting is an effective software 
product that many ТІ-99/4 users will enjoy playing ге- 
peatedly. Potential third-party software developers would 
do well to study the way this product has been implemented. 


Wildcatting 
TI BASIC; 16K 
$14.95 (Cassette) 
Image Computer Products, Inc. 
Northbrook, Illinois 


The Attack* 


They're coming from another world—from 
deep space! Suddenly you're surrounded by 
an infestation of spores. You must destroy 
the spores before an alien is formed. The aliens 
are here. Their numbers are growing. And 
they're coming for you! Your mission... 
Destroy the aliens before they destroy you. | 
The world is counting on you. Good luck, 
Commander. 


By W. K. Balthrop 


than impeccable will power—if you hope to get any 

serious work done after you've made the mistake of 
unboxing this single-player video game to just "check it out 
and make sure it works..." You'll soon discover the true 
significance of the game's name. No, | don't mean an 
"attack" from some bowlegged TV sets with an affinity for 
the Charleston who try and pass themselves off as aliens. 
What | do mean is an "attack" on your time—complete 
with hypnotic music and engrossing, fast-paced ,edge-of-your- 
seat action that can temporarily erase from your mind a 
few of life’s minor details such as family, eating, and sleep- 


Y ои"! need more than luck, Commander—nothing less 


5 


ing... A word of warning: If you use the TI Wired Remote 
Controllers, don’t play the game within one hour of having 
to do something that involves the critical usage of your 
hands—e.g., the finger dexterity needed for brain surgery or 
for a flamenco guitar performance. After an exciting bout 
of The Attack with its inevitable frenzied clutching at the 
controls, your hands will need a rest, Commander. 

Learning to play the game by reading the brief instruc- 
tion booklet shouldn’t take more than a few minutes. But 
learning to play the game we// is another matter; it requires 
very quick reflexes, manual dexterity, and total concentra- 
tion. | just don’t think that very many players will have to 
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worry about remembering to add both scores when the 
score display rolls over at the maximum 500,000 points and 
restarts at 000000! 

The game operates on four skill levels. The level chosen 
determines the number of incubators, concentration of 
spores, and the speed of attacking aliens. Colored numbers 
appear inside the incubators and start counting down. When 
an incubator reaches zero, two or three spores, or an alien 
hatch. The hatching life-form depends on the skill level 
chosen, and the stardate the player is presently in. Spores 
can’t attack, but must be destroyed before four of them 
cluster into a square and form a large, hungry red alien who 
pursues your ship. It's then you or him, Commander . . . 
either blast the menacing creature to smithereens, or be 
gobbled up by the inter-galactic gourmand. If the latter 
occurs, your initial ship supply of ten is depleted by one, 
and the fight continues in another section of the galaxy. 
But if, on the other hand, you're fortunate enough to possess 
the skill of Luke Skywalker, and destroy all the aliens and 
all but ten spores, you will receive an extra ship with which 
to continue your attack in another threatened sector. 

You use the four directional arrow keys to control your 
ship’s movement, and either the SHIFT or ENTER key to 
fire the laser. Alternately, one of the TI Wired Remote Con- 
trollers can be used instead of the keyboard. Caution: І 
don't suggest you use the SHIFT key because of its proxim- 
ity to the Z key—i.e., an accidental SHIFT Z (easily done 
in the "heat of battle") will terminate the present game and 
take you BACK to the level-of-difficulty screen. Therefore, 
If you don't want your potential record-setting game to be 
cut short, use the ENTER key (or the wired Remote Con- 
trollers) to fire. 

This brings up the question of whether or not the Wired 
Remote Controllers—more commonly known as “joysticks” 
—provide an advantage. Although this device allows players 
to keep their eyes concentrated on the screen action with- 
out having to occassionally check their finger placement on 
the keyboard (an often fatal tactical error), the response to 
commands is markedly slower and less precise. It is definite- 
ly more enjoyable and realistic to use a joystick, yet in all 
but the lowest level of play, I’m afraid you'll eventually 
yank out the connecting cable of the TI joystick in frustra- 
tion, and resort to tapping away at the keyboard. [We at 
99'er Magazine have noticed a significant improvement in 
joystick action by using an Atari joystick that is connected 
to the T1-99/4 with an adapter manufactured by Denali 
Data-Ed.| A very skillfull Commander (one who can 
rub his stomach, pat his head, wink, wiggle both ears, and 
alternately snap his fingers—all simultaneously) will be able 
to forgo joysticks altogether, keep his eyes permanently 
glued to the screen, and rid the cosmos of these malignant 
Milton Bradley-created menaces . . . 

One final tip: Before choosing your skill level and rush- 
ing off to do battle, take the time to watch several pre- 
programmed sample “games” that run continuously once 
the Command Module is selected. Pay no attention to the 
actions taken by the “dumb” (randomly firing) Commander. 
Rather, watch closely how the spores move and cluster to 
form aliens, and how the aliens move around spores and 
attack the ship. Try and train your eyes to take in the "big 
picture" all at once, so that you can anticipate where the 
next attack will come from. 

So go to it, Commander. Show your friends and neigh- 
bors that the ТІ-99/4 now has a game that rivals the best of 
the video arcades. And think of all those quarters you'll be 


saving... 6 
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welcoming you 
to the wonderful world of the 


TI 99/4 


* Space Bar Bandit 


A definitive slot machine game! Sounds, 
graphics, plus voice (for machines with TI 
voice synthesizer). One or two players. 


Bio Rhythms Il 


A great demo program! Graphs colored 
bio rhythm curves while you watch! Plots 
for one person—or for two people 
simultaneously! 


Number Please 


All the excitement of Master Mind® with 
many extras! Graphics, sounds, plus voice 
(for machines with TI voice synthesizer). 


All three for just 


$7.95-Tape or $11.95-Disk 
(Regularly $9.95-Tape and $14.95-Disk) 

Disk and tape are compatible with 

standard TI disk and tape systems. 


Hurry! This offer expires 
June 30, 1981. 


Please send me Tapes @ 7.95 $ 
Disks Ф 1195 | 5 
Please add $1.00 for shipping & handling +$ 
Florida residents add 4% sales tax +$ 


Total Enclosed | 5 


| don't wish to order at this time, but please sand me additional 
information on TI 99/4 software. 


— Dealer Inquiries Welcome — 


Name 


Address 


сну 


State/Zip 


Make check or money order payable to: 


TIMORE 


PRODUCTS 


Dept. 99 » P.O. Box 1431 
Winter Park, Florida 32790 


FORUM 


In this column, readers are invited to share their discoveries 
of bugs and/or fixes with the rest of из... 


Subject: 


Missing Dates and Device Default Error in 


“Checkbook Manager” Software 


Fix Status: 


Fixable by User; Method Follows 


Submitted Ву: М.К. Balthrop & G. В. Michaels | 
c/o 99'er Magazine 


We have discovered two bugs in TI's recently released, 
diskette-based Checkbook Manager software package. Both 
bugs are user-fixable, and shouldn't take more than about 
15 minutes to correct, 


CHECKBOOK PROGRAM 


The first bug is in the CHECKBOOK program. An incor- 
rect variable assignment causes erroneous data to be placed 
in the date column. You should, therefore, make this first 
fix prior to starting a data file, or the many hours spent in 
file creation will have to be repeated. 

The procedure we recommend for this, and all diskette- 
based program changes, is to (1) make a back-up copy of 
the disk, (2) make and test out the “fix” on this back-up 
copy, (3) transfer the corrected program to the original disk, 
(4) put away the original disk for safekeeping, and (5) use 
the back-up disk as your “work disk.” Then, if this program 
work disk is ever damaged, you'll still have the original disk 
from which to make a new one. Don't forget to also make 
a copy of any data disk that you use with a program. If you 
want the maximum protection from disk damage and its ac- 
companying file loss, data disks have to be re-copied after 
each file update session. (And with Checkbook Manager it 
is your data disk that is more likely to be damaged due to 
the program's frequent reading from and writing to the 
resident files.) 

Assuming you now have a back-up copy of Checkbook 
Manager (if you need instruction in copying disks, see pages 
22-24 in the Disk Memory System users manual), you are 
now ready to make the first fix: 

1. Select TI-BASIC 

2. Insert the back-up disk in Drive #1. 

3. Туре in OLD DSK1.CHECKBOOK and then press 
ENTER. 

4. When the cursor reappears, either type in 4502 and 
press SHIFT : or type in EDIT 4502 (either keystroke 
sequence will put you into the EDIT mode). 

5. Line 4502 should appear. If the statement reads D$=Q$ 
it is already correct, so just press ENTER. If the state- 
ment reads D$=A$ you must use the right-arrow key to 
position the cursor over the letter A and change it to 


letter Q. Now press ENTER. Wait until the cursor reap- 
pears, type in LIST 4502 and check that it now reads 
D$=Q$ 

6. Type in SAVE DSKI.CHECKBOOK AND PRESS 
ENTER. 

7. RUN the program with some "dummy" data according 
to the TI documentation. You should now see the dates 
correctly displayed. When you're satisfied that the 
revised program is working correctly, copy it onto the 
original ТІ disk. 

8. Put the original TI program disk in a safe place, label 
your new work disk (with the addition 99’er Rev. 5.81.1), 
and use it to manage your computer checkbook. 


ACCTSUM PROGRAM 


The second fix is in the ACCTSUM program. It is only 
necessary if you want to use an RS232C-compatible printer, 
If you will only be using the TI Thermal Printer, the pro- 
gram will work even though it contains the bug (because it 
automatically defaults to the “TP” device name). 

We won't go through the entire step-by-step procedure 
as we did with the previous bug, since this “fix” requires 
several code changes. Follow the same general test and trans- 
fer procedure. 


1. In line 210, move the closing “ to the space immediately 
after NAME? 

2. Insert new line 396 GOSUB 800 

3. Delete line 410 

4. Change line 490 to read 
490 PRINT "DEFAULT""TP""THERMAL PRINTER" 

5. Insert new line 501 IF PRINT$»" " THEN 510 

6. Insert new line 502 PRINT$="“TP” 


The corrected program should now (as it was originally 
intended) allow you to type in your device name (e.g., 
RS232/2.BA-9600) and send the printed ACCTSUM out- 
put to your external printer. Фо 
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желі маарай 


nd 


in TI BASIC 


— 
orget all the educational and technical stuff you've been reading 

Р in the rest of this magazine. Sure, it’s been interesting and infor- 
mative . . . but you need some fun too! Right? Relax then. You're 
in my territory now: Kelley’s Korner—the place for great graphic 
games and sensational simulations. 

Call me Kelley. ГП be your guide here, and will lead you through a 
lush landscape of action, adventure, and challenge. On this first trip 
we'll allow our imaginations to soar, and let our home computers pit 
us against devious foes bent on our destruction. 

I've chosen three confrontations to test your mettle. You're in for 
a smorgasbord of hypnotic involvement, relentless pressure, and con- 
stant decision-making . . . and most of all-FUN! 

But lest I be criticized by others on the staff of this magazine for 
“not teaching you anything of value,” I can only suggest to these 
critics that they look very closely at my carefully chosen itinerary 


Enemy Attack 


By Charles Ehninger 
408 Flaxseed Lane 
Fort Worth, TX 76108 


Anti-Aircraft Gun 
By Mark Moseley 


99'er Мачагте 


for this first issue's excursion into the world of action games. If they Invasion 

do so, they'll find—and may be even learn from—an extensive array 

(no pun intended) of fully documented game programming techniques from Space 
that come in quite handy in a TI BASIC environment. Enough said. By W. K. Balth 
The enemy is at hand. There's no time to waste... y Bor Maa га! rop 


Enemy Attack 


he problem with most action 
Т games written in TI BASIC is their 

speed. Because they are so slow, 
the author must limit himself to no 
more than three moving objects (as in 
pong-type games). More than three of 
these “sprites,” and the player soon falls 
asleep. This is the hammer with which 
my Assembly programmer friends beat 
me over the head every time we have 
coffee together. | am a BASIC program- 
mer, | love challenges, and І don't want 
any more Jumps on my head. So І ac- 
cepted, and here is my reply: An action 
game with many “sprites” that is guar- 
anteed to keep you awake until 3 o'clock 
in the morning. 

My first task was to design the game. 
No more space or intergalactic nonsense 
for me! І much prefer war games now, 
so | borrowed an idea from World War 
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By Charles Ehninger 


Il. To be conclusive, my game needed to 
have several moving objects: | included 
seven aircraft, 9 missiles and forty-five 
blinking, changing and disappearing 
stars. 15 the game exciting? You'll be the 
judge... but first let me tell you that | 
had trouble finishing the program be- 
cause | found myself playing the game 
—trying to repel wave after wave of in- 
vaders—until 3 or 4 o'clock in the 
morning! 

In this game, you are flying a recon- 
naissance mission when your radar 
alerts you to an enemy attack. The 
enemy is flying three squadrons of six 
aircraft each, led by the “rookies.” 
Your radio is out, so you can't alert 
your base. You must fight all by your- 
Self, because if you let a single airplane 
get behind you (or you let them destroy 
you), your home base will be lost. For- 


tunately, your plane is equipped with a 
triple-missile guidance system. That is, 
it can monitor (visably on the screen) 
the flight of up to three missiles simulta- 
neously, whereas the enemy is equipped 
with single-missile systems. To launch a 
missile, you must press the ENTER key. 
(After launching three missiles, the 
ENTER key will be deactivated until 
one of your missiles disappears.from the 
screen.) You may also change your loca- 
tion to intercept the enemy. You may 
move up or down by pressing the corres- 
ponding arrow key, or you may remain 
in onc place by depressing any other 
key. Once the motion is selected, it will 
remain active until changed. Whatever 
your command, hold the key down un- 
til the “acknowledge tone" is emitted. 
The tone indicates that your command 
has been received. а 


ENEMY ATTACK : List of Variables 


1. Numeric Arrays: 


Name 
С 


Elements Purpose 
6x8 (48) There are six row vectors, each assigned 
to one of six attacking air craft. the 
elements are: 
1 -Row location of craft and its associ- 
ated missile. 
2 -Columnar location of aircraft. 
3-ASCII code of character assigned to 
the aircraft, 
4 -Indicator which determines whether 
or not aircraft is "alive." (O=off, 1=on) 
5 -Indicator to show a ‘missile in pro- 
gress” (O=off, 1-оп) 
6 - Column location of missile. 
7-Holds background character to re- 
place the present location of aircraft, 
8 -Holds background character to re- 
piace the present location of missile. 


2. Numeric variables: 


Name 


нано om с 


< 


Purpose 
Row location of friendly craft. 
Normally 0; set to 1 if either the friendly aircraft is 
shot down or an enemy airplane gets through. 
Incremental motion of friendly aircraft (1-down; 
—1=ир) 
Row location of explosion, 
Columnar location of explosion. 
General purpose (FOR-NEXT loops). 
General purpose (FOR-NEXT loops). 
General purpose random number holder, 
Holds background character to replace the present 
location of friendly craft. 
Return variable for input command. 
Status variable for input command. 
Number of enemy aircraft remaining, 
Enemy missile launch indicator (О=попе; 1=launch) 


GM Used to cycle through the full battle 3 times, 


D 3x4 (12) There are three rows of vectors, one for 
cach “friendly” missile. The elements Display Characters: 
1 -Row location of missile. Number Assignment: 
2 -Column location of missile. 96 “Friendly” aircraft. 
3 -ASCII configuration of missile char- 97 White explosion cloud, 
acter. 104 “Enemy” aircraft. 
4 -Background character to replace the 105 Red, yellow or blue cloud. 
present location of the missile. 112 “Fixed” stars. 
P 3 Foreground color number for each group 113 Yellow cloud, 
of attacking aircraft. 120 “Friendly” missile. 
R 4 Foreground colors for star group #1. 121 Red cloud. 
S 4 Foreground colors for star group #2. 122 “Enemy” missile. 
EXPLANATION OF THE PROGRAM 
Line Nos. one active missile, line 1610 checks to deter- 
100-390 Program initialization: Character assignments mine if there is a missile already in progress, If 
and color designations, not, a second test is made in line 1620 to insure 
400-690 Display of game title and introductory music. that the craft is still “alive.” Finally, line 1630 
700-760 Switch star colors at random. В prevents the firing of missiles when the plane is 
770-1540 Defense: The defensive cycle consists of three at or beyond display column 30. Line 1640 
major routines: Input command (770-1000), generates a random number within ever-nar- 
missile advance (1010-1320), and aircraft mo- rowing ranges and line 1650 bypasses missile 
tion (1330-1540). firing if the number is greater than zero, If a 
Input command: The player controls the fir- missile is to be fired, indicator FR is turned 
ing of a missile (ENTER key (13)), upward on. 
motion of the aircraft (UP-arrow (69)), down- Missile advance: Active missiles are advanced 
ward motion (DOWN-arrow (88)) or he may one position and any missile-to-missile or mis- 
command the airplane to remain in present sile-to-craft conflict is resolved, 
position (any other key). Aircraft advance: If a missile has just been 
Missile advance: Lines 1050-1320 are executed fired (line 1900) or a randomly-generated 
three times, once for each missile. Line 1060 number is positive (line 1910-1920) aircraft 
is a quick bypass for unfired missiles. motion is suspended; otherwise, the enemy 
Aircraft motion: The aircraft is repositioned craft advances one position. 
by incrementing A with the contents of E. 2180-2260 Explosion simulation. An explosion cloud is 
Note that E may be any integer between —1 displayed at location F,G. 
and +1. This determines whether the craft 2270-2540 Initial scenario. Sky and friendly craft are 
ascends, decends or remains in place. positioned, 
1550-2170 Offense: The offensive cycle also includes three 2550-2710  Initialization of enemy aircraft, 
phases: Missile firing (lines 1550-1690), missile 2720-2770 Program root. This is the game “clock”, 
advance (1700-1890) and aircraft advance 2780-2800 “YOU WIN” message. 
(1900-2170). 2810-2820 “YOU LOSE” message. 
Missile firing: Since each craft тау sustainonly 2830-2890 “REPEAT?” and loop or end. 
100 REM Ея 190 МЕХТ 1 
110 REM з ENEMY ATTACK ж 200 FOR 1=1 TO 4 
120 REM ЗК ХУ 210 READ В(1),5 (1) 
121 REM BY CHARLES EHNINGER 220 NEXT 1 
122 REM 99”ЕҢ VERSION 5.81.1 230 рата 8,11,7 
130 OPTION BASE 1 240 DATA 1,16,5.16.16,5,16,1 
140 DIM C(5,8) , DS, 4), PU ,RGID ,8 00) 250 CALL CHAR(G OSOSSFF39303000") 
150 CALL CLEAR 260 CALL CHAR (97, "12345EFC7F2F4A90") 
160 CALL SCREEN (2) 270 CALL CHAR (156, "08") 
170 FOR 1=1 TO 5 280 CALL СНАВ(128, "08") 
180 READ PCI) 290 CALL CHAR (104, "OCOCSCFF9COCOC*) continued 
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Enemy Attack, continued from p. 41 1170 IF C(H,1)42D(I,1) THEN 1260 
1180 IF D(1,4)<>122 THEN 1220 
300 CALL CHAR(105, "12343EFC7F2F4A90") 1190 СН, 5) 50 
310 CALL СНАЯ (112, "1818"? 1200 Сін.) 20 
220 CALL СНАЯ (115, °12343EFC7F2F4A90") 1210 GOTO 1270 
1 330 CALL CHAR(120, "OOOOOEFCOE") 1220 C(H,2)=a 
340 CALL CHAR(121,"12343EFC7F2F 4A90" ) 230 C(H,4)=0 
350 CALL CHAR(122,"0000703F70") 1240 ЕМЗЕМ-І 
360 CALL COLOR(G, 16,1) 1250 GOTO 1270 
270 CALL COLOR(IO,2, 1) 1260 NEXT H 


280 CALL COLOR(11.12,1) 
390 CALL COLOR(12,7.1) 


400 REM XIXIXTirk 1290 GOTO 1320 
410 REM Ж TITLE з 1300 CALL HCHAR(D(I,1),D(1,2) ,120) 
420 КЕМ кизікилях 1310 CALL SOUND(-100,110,8,-6,4) 
450 DISPLAY ТАВ(10) ; "ENEMY ATTACK! 1320 NEXT I 
440 CALL нснак(е,7, 104, 217 1330 REM s*tfirgiiriikY 
450 CALL УСНАЯ (7,27,120,15) 1340 REM з DEF MOVE з 
460 CALL НСНАК (20, 7,96, 21) 1350 REM к«ккакккрвакі 
470 CALL VCHAR(7.7,122.13) 1350 IF ЕЗО THEN 1540 
480 CALL SCREEN(8) 1570 CALL HCHAR(A,31,L) 
490 FOR F=6 ТО 20 STEP 14 1280 А=А+Е 
500 FOR 9-8 TO 26 STEP 8 1390 IF а THEN 1420 
510 GOSUB 2210 1400 А=1 
520 NEXT G 1410 Е=0 
| 550 FOR 121 TO 500 1420 IF А<25 THEN 1450 
| 540 МЕХТ І 1450 A=24 
550 GOSUB 580 1440 ЕХО 
| 560 NEXT F 1450 CALL GCHAR(A,31.L) 
570 GOTO 2300 1460 IF (L=32)+(L=112)+(L>127)<>0 THEN 1520 
| зво CALL SOUND(500,440,0,-4,0) 1470 Ғ= 
| S90 CALL SQUND(150,523,0,-4, 1 
200 CALL SOUND(450,523,0,-4,0) 1490 GOSUR 2210 
&10 CALL SOUND(150, 466,0, -4, 0) 1500 В=1 
620 CALL SOUND(1$0,440,0,-4,0) 1510 GOTO 1540 
650 CALL SOUND (150, 592,0,-4,0) 1520 CALL НСНАВ (а, 51,96) 
640 CALL SOUND (450, 440,0, -4,0) 1530 CALL SOUND (50, 440,8, -4, 0) 
b50 CALL SOUND (450, 466.0, 4,0) 1540 RETURN 
| 640 CALL SOUND (450, 494, 0, -4, 0) 1550 REM ffffifikk 
| 470 CALL SOUND (450, 523, 0, -4, ©) 1560 REM я ENEMY з 
| 680 RETURN 1570 REM 113333134 
690 GOTO 2500 1580 GOSUB 730 
700 REM *sztiriki 1590 FOR 1-і TO 6 
710 REM * STARS ж 1600 FR=0 
720 REM #1411%1%%4 1610 IF С(1,5) <>0 THEN 1700 
| 750 FSINT(42RND) +1 1620 IF C(1,4)=0 THEN 2150 
740 CALL COLOR(15,R(F),1) 1630 IF C(I,2)>30 THEN 1900 
750 CALL COLOR(14,S(F) ,1) 1640 J-INT (GMEENXRND) 
| 760 RETURN 1650 IF J THEN 1900 
| 770 REM кажахакняє 1660 С(1,5) =1 
780 REM t DEFEND t 1670 C(1,6)=C(I, 2) 
| 790 REM жа 1680 С(1,8) =С(І, 5) 
й 800 CALL KEY(0,V,W) 1690 FR-1 
810 IF W-O THEN 1040 1700 CALL HCHAR(C(1,1),C(I, 6) ,C( 1,8) 
820 IF У<215 THEN 9 1710 C(I,5)-CUI, 6081 
830 CALL SOUND(-400,440,0,880,0,-4,0) 1720 IF С(1,6) =52 THEN 1850 
840 FOR 1-1 TO 3 1730 CALL BCHAR(C(I.1),C(1,6) , CCI,8) 
850 IF D(1,3)470 THEN 910 1740 IF (С(І,8) =52) + (С(1.8) 2112) €(CCI 82 233270 45 
860 0(1,1728 THEN 1880 
870 D(1,2)=34 1750 Ғ-С(1,1 
880 D(1,3)=1 1760 G=C(1,6) 
890 DiI, 4)=96 1770 GOSUB 2210 
900 БОТО 1040 1780 IF C(I.8)-96 THEN 2020 
910 NEXT I 1790 FOR H-1 TO 2 
920 вото 1040 1800 IF D(H,2)K2C(I,6) THEN 1840 
950 CALL SOUND(-400,110,0,1239,0,-8,0) 1810 D(H,2 
940 IF V<>69 THEN 970 1820 D(H,3 
950 Е=-1 1820 GOTO 1850 
эво GOTO 1040 1840 NEXT Н 
970 IF V«288 THEN 1000 1850 C(1,5)=0 
980 E=] 1850 С(1.6) =0 
990 GOTO 1040 1870 GOTO 1910 
1000 ЕХО 1880 CALL HCHAR(C(I,1),C(1,60 122) 


1010 REM 3355185535418 
1020 REM ж DEF FIRE t 
1030 REM *s3t3t133k3í 
1040 GOSUB 730 

1050 FOR I=t TO 3 


CALL SOUND (-200, 155, 16, -5, 12) 

IF FR THEN 2160 

J=INT (GM*EN*®RND? 

IF J THEN 2160 

CALL НСНАН(С(1,1),С(1,2),С41,7)) 


1060 IF D(I,3)=0 THEN 1520 1940 С(І.2) =С (1,2) +1 
1070 CALL HCHAR(D(I,12,DCI, 22), DC I, 40D 1950 IF C(I,2) >52 THEN 2020 
1080 IF D(I,2)=1 THEN 1270 1960 CALL вснав(с(І,1),С(1,2),С(1,7) 
1090 D(t1,2)-2D(1,2)-1 1970 IF (CCL, 7)=32)+ (CCE, 72 112) € CECI, 7} 23127» «20 
1100 CALL GCHAOR(D4I,1),DCI, 2) ,DCI,4)) THEN 2140 
1110 IF (D(I,4)232) + (001,4) =112) € (DCI 42 2127) 520 1980 F-C(I,1) 
THEN 120 1990 беС(І.2) 
1120 IF D(1,4)-120 THEN 1270 2000 GOSUB 2210 
1150 F=D(1,1) 2010 IF С(1,72<>96 THEN 2040 
1140 G=D(1,2) 2020 веі 
1150 GOSUB 2210 2030 GOTO 2170 
1160 РОЯ Н-1 TO © continued on p. 45 
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Invasion from Space 


fter producing my own TI BASIC 
А59 of the familiar “Ѕрасе 

Invaders” game, it was immediate- 
ly obvious to me why the arcade version 
enjoyed its great popularity—SPEED. 
Since my game had over ninety moving 
objects, it was easy to become bored 
waiting around while they all moved. | 
strongly felt that a computer game 
should be challenging enough to hold a 
player's interest regardless of its interac- 
tion speed, so it was back to the plan- 
ning stage... 

The solution | came up with was fair- 
ly straightforward, but added a new level 
of strategic sophistication to the basic 
“you-blast-me-I-blast-you” game plan. 
Boredom immediately became a thing 
of the past. The first change was to 


By W. K. Balthrop 


missiles. At a given elevation, each mis- 
sile will split into three warheads—each 
travcling in a different direction. To 
compensate for this obvious breach in 
the galactic SALT agreement, | have 
equipped your interceptor jet with the 
capability of firing its laser in thrce di- 
rections at any of the sixty alien ships. 
You can also destroy warheads that are 
in a direct flight path with your jet, or 
hide behind any of the three barriers. 
But don't sit still forever—this tempora- 
ry protection won't last long once the 
multiple warheads start striking! 

The main difficulty in writing /nva- 
sion from Space was in keeping it sim- 
ple for the player while producing the 
fastest program possible. By keeping da- 
ta (status and locations) for the alien 


cycle through each of them in FOR- 
NEXT loops. Next in importance was to 
break all functions into subroutines, so 
they could be accessed at any time in 
the main control loop. Four main sub- 
routines make up the program: 

1. The тат contro! loop: Updates 
enemy positions, branches off to the 
other three subroutines, and reads the 
keyboard. 

2. The defensive routine: Moves the 
jet left or right; fires jet missiles, and 
checks for hits, 

3. The offensive routine: Selects an 
alien ship to fire a missile; controls the 
missile's direction, multiple warhead 
split, and checks for any hits. 

4. The scoring display: Adds or sub- 
tracts points from your score; branche 


equip the aliens with multiple warhead ships and missiles in arrays, | was able to | to end of game messages. 
EXPLANATION OF THE PROGRAM 250 A(2,X) 2 (X32) +4 
260 А(1,0-5 
Line Nos. 270 B(2,)0 2 (X82) +4 
190-600 Initialization: Set up variables, character 280 аўды ва 
definition, and color assignment. 500 C(2; X*«12) = (X12) +4 
610-800 Print instruction page. 210 C(2,X*24) = (X12) +4 
810-1090 Display: playing screen. 320 C(1,X)=7 
1100-1610 Main program control loop. 550 C(1,X*12) 29 
1100-1390 Move alien ships left or right. 340 С(1,Х+24) =11 
1400-1450 Branch to subroutines, зза NEXT X 
1460-1500 Check enemy position for edge of screen; 389 REM 
reverse direction. | 380 CALL CLEAR 
1510-1610 Read keyboard; branch to jet control sub- 390 CALL SCREEN(2) 
routines, 400 CALL COLOR(10,10,1) 
1620-2110 Defensive subroutines, 410 CALL COLOR(S9,6,1) 
1620-1700 Move-jet-left subroutine. 420 CALL COLOR(11,4,1) 
1710-1790 Movejet-right subroutine. 430 COR COLOR (122753) 
1800-2050 Calculate new score when enemy ishit: 5 , 450 CALL COLOR(X, 16,1) 
10,25 , or 50 points. 460 NEXT X 
2060-2110 Barrier hit by friendly missile: score=score 470 CALL CHAR(96, “0008143E6R491C3E") 
—5 points. 480 CALL CHAR(104, "18187EFFFF7E2442") 
2120-3030 Offensive subroutines. 490 CALL СНАЯ (112, "FFFFFFFFFFFFFFFFE") 
2120.2 Е ; ip to fi -- 500 CALL CHAR(113, "00000000008 1 C3FF") 
PER t Е —— 
2290292 ier hi і абл d 520 CALL CHAR(115,"01010303071F7FFF") 
2790-2920 Barrier hit by enemy missile. 530 CALL CHAR(120, "овововововововов') 
2930-3030 Player's jet hit by alien missile. 540 CALL CHAR(121, "B040201008040201 ¥) 
3040-3510 End-of-game messages; Next game, or end. 550 CALL CHAR(122,"0102040810204080") 
3520-3620 Re-initialize variables for the next game. 560 CALL СНАК (105, "7Е7Е9999809918") 
3630-3780 Display score, 570 CALL CHAR (106, "7ЕЗСІВЗСТЕТЕЗСІВ") 
3790-4540 Defensive subroutines, 580 CALL CHAR(107, "1008100810083С18") 
3790-4020 Fire users missile in one of three directions. 2 CALL о. С 
А Ана 09, "00402010020608") 
4030-4130 Check for type of hit by users missile. 10 REM -PRINT FIRST PAGE- 
4290-4540 Enemy missile is destroyed by friendly 520 PRINT "кзазімуабіом FROM SPACExz£31' 
missile Score=scoret+S , 650 PRINT ::: 
4550-4590 End of program message. 640 PRINT YOU MUST DESTROY THE ENEMY: 
650 PRINT 
90 REM petttrcettsecereteet sy 60 PRINT " BEFORE THEY DESTROY YOU" 
95 REM 1 1 670 PRINT 
100 REM 11NVASION FROM SPACE 480 PRINT CHR$(107)5;" =5 PTS." 
105 REM * x 490 PRINT 
106 REM 31311331113 3233313138 700 PRINT CHR$(104);" =10 PTS." 
110 REM BY М.К. BALTHROP 710 PRINT 
120 REM 99°ER VERSION 5.81.1 720 PRINT CHR$(105);" =25 PTS." 
150 REM 730 PRINT 
140 REM 740 PRINT CHR$(106);" =50 PTS." 
150 REM DESTROY ALL OF THE 750 PRINT 
160 REM ENEMY SHIPS BEFORE 760 PRINT “За MOVE LEFT" 
170 REM THEY DESTROY YOU! 770 PRINT "D- MOVE RIGHT" 
180 REM ---INITIALIZATION-— 780 PRINT FIRE CANNON LEFT" 
190 RANDOMIZE 790 PRINT FIRE CANNON UP" 
200 DIM A(2,12) 800 PRINT "R= FIRE CANNON RIGHT" 
210 DIM B(2,12) B10 REM SET UP PLAYING 
220 DIM C(2,56) 820 REM SCREEN 
230 DIM мсь, 30) 
240 FOR Х=1 TO 12 continued on p. 44 
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Invasion from Space, continued from р. 43 


850 PRINT "PRESS ANY KEY TO START" 
840 CALL KEY(O,K.S) 


850 


IF S=0 THEN 840 


860 CALL CLEAR 
870 FOR X=1 TO 12 

380 CALL VCHAR(A(1,X),A(2,X), 106) 

вто CALL VCHAR(B(1,X),B(2,X), 105) 

900 CALL VCHAR(C(1.X),C (2,20 ,104) 

910 CALL VCHAR(C(1,X+12),C (2, X412) , 104) 
920 CALL VCHAR(C(1,X*24) ,C(2, X*24) ,104) 
930 NEXT X 

940 CALL HCHAR(20,5,112,3) 

950 CALL HCHAR(21,4,112,5) 

960 CALL HCHAR(22,4,112,5) 

970 CALL HCHAR(20,15,112,3) 

980 CALL HCHAR(21,14,112,5) 

990 CALL HCHAR(22,14,112,5) 


1000 
1010 
1020 
1030 
1040 
1050 
1060 
1070 
1080 
1090 
1100 
1110 
1120 
1150 
1140 
1150 
1160 
1170 
1180 
1190 
1200 
1210 


1220 С( 


1230 
1240 
1250 
1260 
1270 
1280 
1290 
1300 
1310 
1320 
1330 
1340 
1550 
1360 
1370 
1380 
1390 
1400 
1410 
1420 
1430 
1440 
1450 
1460 
1470 
1480 
1490 
1500 
1510 
1520 
1550 
1540 
1550 
1560 
1570 
1580 
1590 
1690 
1610 
1620 
1650 
1640 
1650 
1660 
1670 
1680 
1690 
1700 


CALL нснав (20, 25, 112,3) 
CALL HCHAR(21,24,112,5) 
CALL HCHAR(22,24,112,5) 
CALL VCHAR(24, 16, 96) 
CALL VCHAR(1,3,83) 

CALL VCHAR(1,4,67) 

CALL VCHAR (1,5, 79) 

CALL VCHAR (i, 5,82) 

CALL VCHAR(1,7,69) 

асі 

REM MOVE ENEMY LEFT 
REM AND RIGHT 

IF A(2,1)=2 THEN 1150 
IF 4(2,12)251 THEN 1170 
GOTO 1180 

D=1 

GOTO 1180 


A(2,%) =A(2, Юр 
В(2.Х)=В(2, Хх) +0 

2.Х)«С(2,.Х +D 

С(2,х+12) =С(2,х+12)+0 
C(2,X+24) -C (2, Х+24) +0 

IF A(1,X)=0 THEN 1280 

CALL VCHAR(A(1,30 ,A(2, 30 , 104) 
CALL VCHAR(A(1,X),A(2,X) -D,32) 
IF B(1,X)=0 THEN 1310 

CALL VCHAR(B(1,X),B(2,X), 105) 
CALL VCHAR(B(L,30 ,BL2, 2 -D, 32) 
IF C(1,X)x0 THEN 1340 

CALL УСНАЯ (с(1, X) ,C(2, Хх), 104) 
CALL VCHAR(C(1,x),0(2,X)-D, 32) 
IF C(i,X+12)=0 THEN 1370 

CALL VCHAR(C(1,X+12),0(2,X+12), 104 
CALL VCHAR(C (1,X*12) ,C(2, X412) -D,32) 
IF С(1,Х+24) =0 THEN 1420 

CALL VCHAR(C(L, X24) ,C(2, X*24) ,104) 
CALL VCHAR(C(1,X«24) , C2, X424) -D, 32) 
REM BRANCH то 

REM SUBROUTINES 

GOSUB 153 

GOSUB 3630 

GOSUB 2150 

GOSUB 5650 

REM CHECK ENEMY POS. 

Маці 

Х=х+1 

IF POINTS>1090 THEN 5280 

IF W«13 THEN 1200 ELSE 1120 
REM SUB-ROUT INE 

REM OPERATOR INPUTS 

CALL KEY(O,K,8) 

IF $<>0 THEN 1560 

RETURN 

IF K=83 THEN 1630 

IF K=68 THEN 1720 

IF K=69 THEN 4260 

IF K-87 THEN 4180 

IF K-82 THEN 4220 

RETURN 

REM MOVE LEFT 

P2-P2-1 

IF P2=1 THEN 1440 

БОТО 1670 

Р2=Р2+1 

CALL VCHAR(P1,P2+1,32) 

CALL VCHAR(P1,P2, 9) 

CALL SOUND (100, 220, 2) 

RETURN 


1710 
1720 
1730 
1740 
1750 
1760 
1770 
1780 
1790 
1800 
1810 
1820 
1830 
1840 
1850 
1860 
1870 
1880 
1890 
1900 
1910 
1929 
1930 
1940 
1950 
1960 
1970 
1980 
1990 
2000 
2010 
2020 
2030 
2040 
2050 
2060 
2070 
2080 
2090 
2100 
2110 
2120 
2130 
2140 
2150 
2160 
2170 
2180 
2190 
2200 
2210 
2220 


2230 


2240 
2250 
2250 


2270 мі 


2280 
2290 
2300 


2310 мс 


2520 
233! 


2540 
2350 
2360 
2370 
2380 
2590 
2400 
2410 
2420 
2450 
2440 
2450 
2460 
2470 
2480 
2490 
2500 
2510 
2520 
2550 
2540 
2550 
2560 
2570 
2580 


REM MOVE RIGHT 

Р2=Р2+1 

If P2=32 THEN 1750 

GOTO 1760 

P2=P2-1 

CALL VCHAR(P1,P2-1,32) 
CALL VCHAR(P1,P2,96) 

CALL SOUND (100,220, 2) 
RETURN 

REM CALCULATION 

REM ENEMY DESTROYED 
POINTS=POINTS+10 

CALL SOUND (200, 110,2,-7,2) 
FOR Y=1 TO 56 

IF C(1,¥)<>Z THEN 1880 

IF C(2,¥)<>Z1 THEN 1880 
сазе 

NEXT Y 

RETURN 

POINTS=POINTS+25 

CALL SOUND (200, 110,2,-7,2) 
FOR Y=1 TO 12 

IF B(1,Y)<>Z THEN 1960 

IF B(2,Y)<>Z1 THEN 1960 
В(1,Ү)=0 

NEXT Y 

RETURN 
POINTS=POINTS+50 
CALL SOUND (200, 110, 
FOR Узі TO 12 

IF А(1,Ү9<>2 THEN 2040 

IF А(2,У)<>21 THEN 2040 
A(1,¥)=0 

NEXT Y 

RETURN 

REM FORTRESS DESTROYED 
REM BY OPERATOR 

CALL SOUND (100, 220, 2,-6.2) 
CALL SOUND (200, 110,2,-6,2) 
POINTS=POINTS-S 

RETURN 

REM CALCULATION 

REM SELECT SHIP TO 

REM DROP THE MISSLE 


NT (RND#12) +} 
IF C(1,M1+24)=0 THEN 2210 
М(1,М22-С(1,М1%249%1 
M(G,M2) =C (2,М1+24) 

GOTO 2400 

IF С(1,М1«12) =0 THEN 2250 
М(1,М2)=С(1,М1+12) +1 
M(2,M2)=C(2,M1+12) 

GOTO 2400 

IF C(1,M1)-0 THEN 2290 
M(1,M2)=C(1,ML) +4 

2,M2)=C(2,M1) 

GOTO 2400 

IF B(1,M1)-0 THEN 2330 
MCI,M2)=B(1, Mi) +1 

2,M2)=B(2,M2) 

бота 2400 

IF A(1,M1)-0 THEN 2360 
М(1,М2)-А(1,М1941 

M(2,M2)=A(2,M1) 

Wi=wi+1 

IF Wi=60 THEN 2990 

GOTO 2160 

REM DROP MISSLE 

FOR Х2=1 TO 29 

FOR X3=1 TO 5 STEP 2 

IF M(X3,X2)=0 THEN 5550 

IF X3>1 THEN 2490 

IF M(1,X2)<>18 THEN 2490 

MG, X2) M ,X2) 

(2, X2) 

G,X2) 

M(6,X2)=M (2, X2) 

IF M(X3,X2)-24 THEN 2520 

IF M(X3+1,X2)<2 THEN 2520 

IF М(Х5%1,Х2)<51 THEN 2570 

CALL GCHAR(M(G, X2) , MOS 1, X2) , CH) 
IF CH-96 THEN 2950 

CALL VCHAR(M (GS, X22 , MOCGSH 1, X22 ,32) 
MZ, X2) =O 

GOTO 3360 

ON INT(X3/2+1)GOTO 2580, 2610, 2640 
CALL GCHAR (M(XS.X2)+1,M(X3+1,X2),CH) 


continued on p. 45 
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Enemy Attack, continued from р. 42 
2040 FOR H=1 TO з 

2050 IF D(H, 2)<>C(1,2) THEN 2090 
2060 DiH,2)-0 

2070 D(H, 3) =0 

2080 GOTO 2100 

2090 NEXT Н 
2100 Ct1,2)20 
2110 С(1,4) 
2120 EN-EN-1 

2120 GOTO 2160 

2140 CALL HCHAR(CtI,D1),CCO,2),CCO,2)) 
2150 CALL SOUND(-100,659,0,-8,0) 

2150 NEXT І 

2170 RETURN 

2180 REM жағала 

2190 REM з BANG t 

2200 REM tagt 

2210 FOR H-121 TU 97 STEF -8 

2220 CALL HCHAR(F,G.H) 

2230 CALL SOUND(-1000,110,0,165,0, -7,0) 
2240 NEXT H 

2250 CALL HCHAR(F,G, 32) 

2260 RETURN 

2270 REM *ixtikty 

2280 REM % START З 

2290 REM rxriitkgcri 

2300 CALL CLEAR 

2310 CALL SCREEN(2) 

2520 бм=т 

2330 GOSUB 730 

2340 В=0 

2250 A=12 

2360 L=32 

2370 FOR 1-1 TO 5 

2280 р(І,5 
2390 D(I,4) 
2400 NEXT I 

2410 RANDOMIZE 

2420 FOR I=! ТО 40 
2430 FeINT(AERND) +1 


2480 
2490 
2500 
2510 
2520 
2550 
2540 
2550 
2560 
2579 
2580 
2590 
2600 
2610 
2620 
2550 
2640 
2550 
2660 
2670 
2680 
2690 
2700 
2710 
2720 
2730 
2740 
2750 
2760 
2770 
2780 
2790 
2R00 


2920 DI 


2паа 
2ASO 


6070 2550 

IF ІМТ (F+6)/2)=(F+6)/2 THEN 2520 
CALL HCHAR(F,8,128) 

GOTO 2530 

CALL HCHAR(E,G, 126) 

NEXT i 

CALL HCHAR(A, 21,96) 

CALL COLOR(GO,P(GM) L0) 

FOR I=1 TO 6 

J=INT (24¥RND) +1 

FOR H=! TO 1-1 

IF J=C(H,1)THEN 2570 

NEXT H 

С{1.1)=2 

СТ, 22 =1 

С(1,5)=104 

С(1,4)=1 

С(1,5)=0 

ССІ,6уєі 

С(1,7)-52 

С(І,8) 2104 

CALL нснак (С(1,1),С(1,2),С(1,23)) 
CALL SOUND(50, 1519, 0) 
МЕХТ І 

EN-ó 

GOSUB воо 

GOSUB 1580 

IF Веі THEN 2820 

IF EN THEN 2750 

GM=GM~1 

IF GM THEN 2550 

CALL CLEAR 

DISPLAY [AB(10);"DUR HERO! 
SAVED YOUR COUNTRY”: 
GOTU 2840 

сам. CLEAR 

SPLAY TAR(G):"SEE WHAT YOU'VE DONE? 
“YOU LET THE ENEMY DESTROY": "YGUR 
COUNTRY ' " : 

DISPLAY “WANNA TRY AGAIN"; 

сац. SCREEN(B) 


YOU HAVE 


2440 G=INT(32*RND) +1 2860 INPUT ке 

2450 CALL SOUND (-50,880, 8) 7870 IF БЕОФ (КЖ, 1, 1) 2^ Y" THEN. 2300 
2460 IF I»19 THEN 2490 2880 CALL CLEAR 

2470 CALL HCHAR(F,G, 112) 7890 END 

Invasion from Space, continued from p.44 2990 IF POINTS«400 THEN 3060 


2590 X4=0 

2600 GOTO 2660 

2610 CALL GCHAR (М (х5, X2)+1,M(X3+1,X2)-1, CH) 
2620 ХА=-1 

2630 GOTO 2660 

2640 TALL GCHAR (MUXS, X2) +1,.M(X341,X2) +1, CH) 
2650 X4=1 

2660 ІР CH-112 THEN 2820 

2670 IF CH-96 THEN 2950 

2680 M(XS,X2) 2M(OXGG, X20 +1 

2690 М(Х2%1,Х2) =М(Х5+1,Х2) +Х4 

2700 CALL VCHAR (M CCS, X2) -13, MUGG*1, X22 -X4, 52) 
2710 CALL SOUND(ZO,440,10) 

2720 ОМ INT(X3/2+1)G0TO 2750, 2750, 2770 
2750 CALL VCHAR(M(1,%2),M(2,X2).107) 

2740 GOTO 3360 

2750 CALL VCHAR(M(G, х2),м(а, Х2), 108) 

2760 GOTO 3360 

2770 CALL VCHAR (M(5,X2),M(6,X2), 109) 

2780 GOTO 3360 


2790 REM CALCULATION 
2800 REM FORTRESS HIT BY 
2810 REM MISSLE 


2820 CALL VCHAR(M(XZ, X2) M(X3+1, X22 52) 
2820 ON INT(X3/2+1) БОТО 2840, 2840, 2880 

2840 CALL VCHAR (M(4,X2)4+1.M(2,X2), 213) 

2850 GOTO 2890 

2860 CALL VCHAR(M CS, X2) 81, M (4, X2) 1,114) 
2870 GOTO 2890 

2880 CALL VCHAR(M(5,X2)+1,M(6,X2)+1, 115) 
2890 РОІМТ85-РОІМТ5-5 

2900 CALL SOUND (200, 110,2,330,5,-5,2) 

2910 моху, Х2) =а 

2920 GOTO 3370 

2930 REM OPERATOR HIT BY 

2940 REM MISSLE 

2950 CALL CLEAR 

2960 CALL SOUND (1000, 110, 2, 220, 2,330, 2,-4.2) 
2970 REM SELECT END OF 

2980 REM GAME MESSAGE 


3000 
3010 
3920 


3070 
3080 
3090 
3100 
3110 
3120 
3130 


40 
2150 
5160 
3170 
3180 
3190 
3200 
3210 
3220 
3230 
3240 
5250 
3260 


2100 

ТЕ POINTS<9¢ 3150 

IF FOINTS<1000 THEN 2210 

GOTO 3280 

REM PRINT END OF GAME 

REM MESSAGE 

PRINT "YOU BLEW IT. THE ALIENS HAVE" 
PRINT “TAKEN OVER THE EARTH" 

PRINT “YOUR SCORE IS:";POINTS 


SOTO 2410 

PRINT "YOU HAVE LOST THE WAR WITH" 
PRINT "THE ALIENS. YOU MUST MAKE тах" 
PRINT "PAYMENTS TO THEM" 

PRINT "YOUR SCORE IS:":POINTS 


GOTO 5410 

PRINT "BOTH THE EARTH, AND THE" 
PRINT "ALIENS HAVE нар GREAT LOSSES" 
PRINT "IT WILL TAKE маму YEARS та" 
PRINT "REBUILD EARTH" 

PRINT "YOUR SCORE IS 
GOTO 5410 

PRINT "YOU FOUGHT THEM DFF BUT" 
PRINT "SUFFERED MANY LOSSES" 

PRINT "THE EARTH WILL RISE ТО POWER" 
PRINT "AGAIN SOME DAY" 

PRINT "YOUR SCORE I POINTS 

CALL SOUND (200, 440, 2,740, 2) 


POINTS 


continued on p. 54 
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Anti-Aircraft Gun 


espite the fact that action games 
D in a high-level lan- 
guage such as TI BASIC run much 
slower than in low-level languages such 
as 9900 assembly language or GPL (the 
programming language of ТІ'5 Command 
Modules), it is indeed possible to create 
reasonably fast "real-time" games if you 
observe a few rules: 
1. Keep the number of moving ob- 
jects to a minimum. 
2.Keep all unnecessary statements 
out of loops used to move objects. 
3. Use only one character to define 


By Mark Moseley 


objects you want to move fast. 

4. Increment the positions by two 
spaces each loop. This makes the move- 
ment slightly jerky, but contributes 
greatly to the illusion of speed. 

I’ve followed these rules in writing 
Anti-Aircraft Gun. The basic idea of the 
game is simple: you must shoot down 
an attacking plane with your missile 
launcher before it blasts you twice with 
its laser. The plane attacks at random 
heights from both the left and right 
sides. Its speed and frequency of laser 
fire are dependent on the skill level you 


choose. Your missile launcher can move 
along the ground, and even hide behind 
a barrier; but when it fires a missile, it is 
committed to its last position until the 
missed shot passes off the screen. You'll 
have to move around as much as possi- 
ble because the plane "remembers" your 
last position with its higher probability 
of firing the laser near that position. 
And don't expect too much protection 
from the barrier: After five laser blasts 
(orless, if you launch missiles through it), 
it will be disintegrated and leave you 


exposed. q 


PROGRAM STRUCTURE FOR ANTI-AIRCRAFT GUN 360 PRINT "THE PLANE FIRES A NEWLY-" 


370 PRINT “DEVELOPED LASER. THE PLANE" 
| EXPLANATION OF THE PROGRAM $80 PRINT “MAY COME FROM LEFT OR RIGHT 


390 PRINT "WARNING! IT HAS A RADAR THA 


Line Nos. 400 PRINT “REMEMBERS YOUR LAST FIRING" 
100-670 Instructions. 410 FRINT "POSITON AND TRIES TO GET YOI 
| 680-810 Set up levels of difficulty. 420 PRINT "THERE,SO BETTER MOVE ARDUND 
| 820-870 Set up variables to make plane fire more as 430 PRINT зії 
| difficulty increases. 440 PRINT "PRESS ANYTHING TO CONTINUE" 
| 880-1 10 Character definitions and color assignments, 229 Баат со, KL, LK) 
1120-1170 Initial displaying of tank. | 470 IF LK-O THEN 460 
1180-1220 Display ground. | 480 PRINT TAE(8):"£ BARRIER: з" 
1230-1260 Calculate plane's height. 490 PRINT 
| 1270-1380 Determine the direction of the plane. 500 PRINT "THE LASER CAN’T PENETRATE " 
1390-1450 Read keyboard, and branch to subroutines. 310 PRINT "THE BARRIER, BUT THE BARRIER" 


520 FRINT “Сам SUSTAIN ONLY 5 DIRECT " 


460-1530 Fire tank’s rock | 
1460-1530 Ғіге tank’s rocket. 550 PRINT "HITS. YOU CAN FIRE WHEN BE 


1540-1610 Move plane. ана 540 PRINT "HIND IT, BUT THIS WILL ONLY" 
1620-1650 Decide whether plane will fire or not. 550 PRINT “SHORTEN ITS LIFE." 
1660-1760 Fire plane's laser; check for hits. | 560 PRINT 
1770-1780 Check for a hit on the plane by the tank’s | 570 PRINT TAB(8);" SCORING: а" 
rocket. 580 PRINT 
1790-1890 Check for plane at the edge of the screen. 970- PRINT C FEANES ARE SCORED ACCORDING” 
SR. Si desi ju 600 PRINT "TO HEIGHT: 5 FOR LOWEST, 20" 
1900-2030 Determine new direction for the planc. &10 PRINT "FOR HIGHEST. IF YOUR SCORE “ 
2040-2090 If plane hits the tank at the same time the м “ 4 ч " 
П $ 620 PRINT “IS OVER 100 THEN YOU GET A 
tank hits the plane, the tank wins. 620 PRINT "FREE BONUS GAME." 
2100-2180 Determine new direction for the plane, 640 PRINT :::::; 
| 2190-2330 Calculate score. $50 PRINT "PRESS ANYTHING TO CONTINUE" 
2340-2420 Print score. 660 CALL KEY(O,KL,LK) 
2430-2460 Plane із destroyed by the tank. $70 TF ко THEN 660) 
5 ч, Mad . ы 680 CALL CLEAR 
2470-2620 Calculate if а free game was won; starts over. 690 CALL COLDR(2.2.8) 
2630-2750 Move tank left m" TLE gn 
630-27 o . 700 PRINT "INPUT LEVEL OF DIFFICULTY: 
2760-2880 Move tank right. 710 PRINT 
2900 END, 720 PRINT "(1) PRO" 
720 PRINT 
740 PRINT " (2) INTERMEDIATE" 
750 PRINT 
100 REM #553311 53358318828 760 PRINT “(3) NOVICE" 
110 REM t з 770 РВІМТ 
120 REM з ANTI-AIRCRAFT GUN 8 780 PRINT "(4) BEGINNER" 
| 130 REM 1 з 790 PRINT : : 
| 140 REM  $212ffIfT311312T921: 1:224: ВОО CALL KEY(O,DIF, XS) 
150 REM BY MARK MOSELEY 810 IF XS=0 THEN 800 
160 REM 99°ER VERSION 5.81.1 820 REM PLANE FIRING MORE 


170 CALL CLEAR AS DIFFICULTY INCREASES 
180 CALL SCREEN(B) 

190 REM з INTRODUCTION з 

200 PRINT TAB(23);"FRESS І FOR INSTRUCTIONS" 
210 PRINT TAB(8);"AND М FOR NONE" : 
220 CALL KEY(O,LP,PL) 879 CALL CLEAR 

230 IF PL-O THEN 22 880 REM DEFINE CHARACTERS 


240 IF LP-78 THEN 680 890 REM BAS-BARRIER, L$- LASER, R$-ROCKET, 
250 PRINT Тав(5);чх ANTI-AIRCRAFT GUN з“ P$ М PR$- PLANE, ТФ Ж TRS=TANK, 

240 PRINT бэз DESTRUCTION 

270 PRINT "THE OBJECT OF ANTI-AIRCRAFT" FFFFFFFF" 

280 PRINT "IS TD DESTROY AS MANY PLANES" "2A044 12289045220" 

290 PRINT "AS POSSIBLE. TO FIRE YOUR " 1818181818181818" 

300 PRINT "MISSLE, PRESS Q. TO MOVE " "1818181818183C7E" 


310 PRINT "LEFT, FRESS 5, AND FOR RIGHT" 
320 PRINT "PRESS D." O60C19FFFF190CO&6" 
550 PRINT O71F7FFFFF7FZFOF" 
340 PRINT TAR(9)} "3 PLANES; є" 970 TRS-"EOFBFEFFFFFEFCEO 
350 PRINT 980 CALL CHAR(120,D$) 


“60 3098F FFF 983060" 


continued 
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Anti-Aircraft Gun, continued. . . 1860 IF B=T+1 THEN 2050 | 
1870 B=B+DIR | 
990 CALL CHAR(144,US) 1880 IF 8252 THEN 1900 ELSE 1890 
1000 CALL CHAR(97,R$) 1890 IF K-81 THEN 1420 ELSE 1400 
1010 CALL CHAR(12,TL$) 1900 RANDOMIZE 
1020 CALL CHAR(112, TRS) 1910 B-INT (2£RND) +1 
1050 CALL CHAR(101, BAS) 1920 REM DETERMINE PLANE'S DIRECTION 
1040 CALL CLEAR 1930 ON в GOTO 1940, 1980 
1050 вахо 1940 В=50 
1060 CALL COLOR (2, 15. 2) 1950 CALL CHAR(94,PR$) 
1070 CALL COLOR(15,2,2) 1960 DIR--2 
1080 CALL COLOR(15,12,8) 1970 бото 2000 
1090 CALL COLOR(13,3,2) 1980 DIR=z 
і 1100 CALL COLOR(12,7,8) 1990 CALL CHAR(95,P$) 
1110 Т=15 2000 RANDOMIZE 
1120 REM INITIAL PRINTING OF TANK 2010 A=2EINT(9#RND) +1 
1130 CALL HCHAR(24,T, 112) 2020 IF A=} THEN 2000 
1140 CALL HCHAR(24,T+1,42) 2030 GOTO 1890 
3 1150 CALL HCHAR(24,T+2, 115) 2040 REM TANK HITS PLANE 
1160 CALL HCHAR(23,7+1, 152) 2050 CALL SOUND(1000,-2,2) 
1170 CALL HCHAR(2,15,101,3) 2060 REM А TIE-TANK WINS- REPRINT TANK 
1180 REM PRINT GROUND (GREEN) 2070 CALL HCHAR(24,T+1, 42) 
1190 CALL HCHAR(23,1, 128, 15) 2080 CALL нснав (25, T+1, 152) 
1200 CALL HCHAR(23,17, 128,15) 2090 CALL HCHAR (A,B, 120) 
1210 CALL HCHAR (24, 1, 128, 14) 2100 REM DETERMINE PLANE’S DIRECTION 
1220 CALL HCHAR(24, 18, 128, 14) 2110 B=INT(2*RND) +1 
1230 REM  A-HEIGHT OF PLANE 2120 ом B GOTO 2130,2170 
1240 RANDOMIZE 2130 В=50 
1250 A-2EINT(91RND)*1 2140 DIR--2 
1250 IF А=1 THEN 1240 2150 CALL CHAR(96,PR$) 
1270 REM DETERMINE PLANE'S DIRECTION 2160 GOTO 2200 
1280 RANDOMIZE 2170 DIR=2 
1290 B=INT(28RND) +1 2180 CALL сная (9ь, F$) 
1300 ON.B GOTO 1510, 1550 2190 REM t SCORING є 
1310 B=30 2200 IF A>13 THEN 2210 ELSE 2250 
1520 CALL CHAR(96,PR$) 2210 SC-SC«5 
1230 DIR=-2 2220 GOTO 2300 
1340 GOTO 1280 2250 IF А>7 THEN 2240 ELSE 2260 
1550 DIR=2 2240 SC=SC+10 
1360 CALL CHAR(S6,P$*) 2250 GOTO 2500 
1370 B 2260 IF А<>5 THEN 2290 
1580 Y=21 2270 SC=SC+15 
D 1390 REM х BEGIN LOOP з 2280 GOTO 2300 
1400 CALL KEY(0,K,5) 2290 SC-SC«20 
1410 REM 81 FIRES ROCKET, 83 AND 68 MOVE TANK ТОО M$=STRS (SC) 
1420 IF K=81 THEN 1450 2310 RANDOMIZE 
Я 1450 IF K=83 THEN 2640 2320 B-2tINT(?1RND) +1 
1440 IF K=68 THEN 2770 ELSE 1550 2330 IF A=1 THEN 2310 
1450 IF Y=21 THEN 1480 ELSE 1470 2340 REM PRINT SCORE | 
1460 REM FIRE ROCKET 2350 FOR Ізі TO LEN(M$) ! 
1470 CALL VCHAR(Y*2,T*1,32) 2560 CV=ASC (SEG$ (M$, I,1)) 
1480 CALL VCHAR(Y,1+1,97) 2370 CALL HCHAR (АА, 221, СУ) 
1490 ТТ=Т+1 2380 NEXT І 
1500 Ү=ү-2 2390 GOTO 1380 
1510 IF Ys-1 THEN 1520 ELSE 1550 2400 FOR ізі TO 1000 
1520 CALL VCHAR(1,T+1, 72) 2410 МЕХТ І 
1530 GOTO 1380 2420 GOTO 1040 
1540 REM MOVE PLANE 2430 REM PLANE HIT TANK 
1550 IF DIR--2 THEN 1570 2440 CALL SOUND(500,-6, 2) 
1560 IF B«3 THEN 1590 2450 CALL CLEAR 
1570 CALL УСНАК (А, B-DIR, 32) 2460 SX-SX«1 
1580 IF B«2 THEN 1900 2470 REM IF 2 GAMES PLAYED, START OVER 
1590 CALL УСНА (A, В, 96) 2480 IF SX<2 THEN 1040 
1600 RANDOMIZE 2490 PRINT ТАВ(7);" GAME OVER 5 
1610 Q=INT(15%RND) +1 2500 PRINT TAB(7);"YOUR SCORE IS";SC 
1620 REM WILL PLANE FIRE LASER? 2510 FOR 1=1 TO 10 
1650 TT=TT-2+INT (0/2) 2520 PRINT | 
1640 IF B=TT THEN 1670 2530 NEXT I 
1650 IF Q»DIFF THEN 1670 ELSE 1820 2540 Sx=0 
1660 REM PLANE WILL FIRE LASER 2550 IF SC<100 THEN 2600 | 
+ 1670 IF BA=S THEN 1760 ELSE 1680 2560 PRINT ТАВ(53;7% YOU GET A FREE GAME ж" 
1680 IF Вхі4 THEN 1690 ELSE 1750 2570 REM % A FREE GAME! t 
1690 ВА=ВА+1 2580 SC-o 
1700 IF BAC>S THEN 1720 2590 GOTO 2400 2750 GOTO 1550 
1710 CALL HCHAR (22, 15,32.3) 2600 $С=0 2760 REM MOVE TANK RIGHT 
% 1720 CALL VCHAR(A+1,B, 144,21~A) 2610 REM GO BACK TO START 2770 IF T>27 THEN 2780 ELSE 2810 
1750 CALL VCHAR(A+1,B, 32, 21-A) 2620 GOTO 480 2780 CALL SOUND(250,110,2 
1740 CALL БОШМ (500, -5, 2) 2650 REM MOVE TANK LEFT 2790 T-29 
1750 GOTO 1850 2640 IF Т<5 THEN 2650 ELSE 2680 2800 GOTO 2820 
1760 CALL VCHAR(A*1,B, 144, 23-0) 2650 CALL SOUND(250, 110,2) 2810 T=T+2 
1770 IF В<>Т+1 THEN 1790 2660 T=1 2820 CALL НСНАВ (24, Т. 112) 
1780 IF AC>Y+2 THEN 2440 2670 БОТО 2690 2830 CALL HCHAR(24,141,42) 
1790 CALL VCHAR1A+1, B, 32, 22-4) 2680 T-T-2 2840 CALL HCHAR(24,T*2. 115) 
1800 CALL VCHAR (23, B, 128, 2) 2690 CALL HCHAR(24, T, 112) 2850 CALL нснан(25, 71, 152) 
1810 CALL SOUND (500, -5,2) 2700 CALL HCHAR(24,T+1,42) 2860 CALL ненае (24, 1-2.128,2) | 
1820 IF В>50 THEN 1840 ELSE 1850 2710 CALL HCHAR(24,T*2,112) 2870 CALL HCHAR(23, T-1, 128) 
1820 IF В<5 THEN 1840 ELSE 1850 2720 CALL HCHAR(23,T+1, 152) 2880 БОТО 1550 | 
1840 CALL VCHAR (A, в, Z2) 2750 CALL HCHAR(24, T«3, 128,2 2890 вота 1040 
1850 IF A<>Y+2 THEN 1870 2740 CALL HCHAR(23,7+3, 128) 2900 END 
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A 99'er Language Tutorial Series 


TMS9900 
Machine & Assembly Language 


Part 1 : Electrical Signals, Number Systems, & CPU Architecture 


By Dennis Thurlow 


#1 #2 #5 #4 


ee аара 
Дае... е. рад. РУ 


HIGH, ЕН 
tow 1 SIGNAL LINE 

8 1 ali в DATA RECEIVED 
HIGH 
нен 2 SIGNAL LINES 
ll "— “зезер--үсеер-:::/2 READ TOGETHER 
Low 

pø Я 18 11 DATA RECEIVED 


Chart 1 


CLOCK PULSES 


READ CYCLES 


aware that there is a difference between 8-bit and 


| f you're a reader of this magazine, you are probably 
16-bit computers . . . although just exactly what that 


difference is—other than “16 bits are twice as many as 8 
bits"—might not be that obvious. My purpose in this series 
of articles is, therefore, to discuss the “іппег workings” of 
your 16-bit computer by gradually introducing you to its 
operation and /ow-eve/ programming (in a language much 
closer to the way your computer operates without any 
BASIC interpreter slowing things down, or coming between 
you and the power of your machine). 

The heart of any computer is its microprocessor, and the 
one we'll be examining is, naturally enough, the Texas In- 
struments TMS9900—the 16-bit chip around which 99'er 
Magazine is dedicated. To understand its operation, we first 
have to know something about electrical signals and num- 
ber systems, so let's begin our discussion here. 


Clocks, Pulses, Bits & Bytes 


The electrical signals used by a computer arc labeled 
high and low, or 1 and O, respectively. One of these signals 
is called a b/t. Inside the computer this corresponds to one 
wire. All of the wires together are called a bus. The com- 
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puter reads and writes to a part of the bus called the data 
bus at specific intervals, regulated by a clock. The signals 
that the clock produces to tell the computer when to read 
and write are called c/ock pulses. 

At each pulse of the clock, the computer reads a group 
of lines. Your normal, run-of-the-mill microcomputer uses 
groups of 4,8,ог 16 bits. All the information read or 


written is called 4а 
on 1 line, the data 
ten on a group of 


ta. If the computer is reading or writing 
is called seria/. If it is being read or writ- 
ines together, the data is called parallel. 


4 bits in parallel are called а nvbb/e; 8 are a byte; and 16 


has no name, but | 
Look at Chart 


propose to call it a gobby/. 
. The top line is the clock. In this exam- 


ple when the pulse is high, the computer reads the signal 
lines. Notice that when there is only one signal line, the da- 
ta received can only be а 1 (when the line is high) or a 0 
(when the line is low). There are only two possible codes 
you could see during one clock pulse. You would see a 1 or 
a0. 

Now look at what happens when you have two signal 
lines grouped together: 4 different codes are possible. On 
clock pulse #1 both lines are low (code 00); on pulse #2 
the bottom line is low and the top one is high (code 01); 
pulse #3 has the bottom high and the top low (code 10); 
and pulse #4 has both fines high (code 11). 


DECIMAL BINARY е 
-.1615[4[3[2] 1 Р-соцомме ‚]6|5[4[з]2]+ [—согомм< Looking 
a е 
аа е 
EE sje for a Gift? 
з” VALUES „т VALUES 
XA маа за 
Га |-PosITIONS 4111112 Positions 
DIGIT x VALUE DIGIT x VALUE 
4x1=4 Ях 1 б 
EE 1x22 2 
Ях 198 =Ø 1х4= 4 
Я x 1888 = 8 1х8= 8 
DECIMAL — TOTAL =14 DECIMAL | TOTAL =14 
BINARY DECIMAL HEXIDECIMAL BINARY DECIMAL | HEXIDECIMAL 
9000 = gg = Я 1999 = 98 - 8 
#901= Or = 1 1881 = 99 = 9 
gig = 92 = 2 179 = 1B = А 
9911 = 93 = з 1811 = 11 = в 
8198: de = а пяра 12 = с Bookstore 
8181: 95 = 5 1181 = 13 = D 
9118 = de = 6 1119 = 14 = Е 
ditte G7 = 7 040110 405 = F ] (pages 32-35) 
Chart 2 


Number Systems 


These codes could also be considered numbers. Counting 
with only 0% and 17% is called binary (from the Latin word 
for two). Ordinary, plain, vanilla numbers that we use суегу- 
day are called decimal (from the Latin for ten, of course) or 
base ten, Even though we only have the ten digits from 0 to 
9, we can make very large numbers by using the same digits 
in different positions. Follow along on chart 2. 

The position on the extreme right in a decimal number is 
the one's column, For that matter, the position on the ex- 
treme right in any base is the one's column. Why? Because 
you find the column value by taking the number of digits 
you have and raising it to the power of column minus one. 
For example, if you have ten digits, and the column is 
number 1 (from the right) then the value of that column is 
10 to the 1 minus 1, or 10 to the 0 power. Any number to 
the 0 power is 1, so the first column is always one's in any 
base. 

The second column is a different matter. In base ten it 
is 10 to the 2 minus 1, or 10 to the 1st power, or 10. So if 
you write 14 what you mean is 4 groups of one's and 1 
group of ten's. In base two the second column (from the 
right) would be 2 to the 2 minus 1, or 2 to the Ist, or 2. 
The second column or position in binary isthe two's column. 

The thing that makes the zero so neat is that it holds the 
position without giving it a value. Zero one's is zero! If you 
just left a blank there, people would have to write all their 
numbers in little boxes or pretty soon the columns would 
get all jumbled up. Is there one blank or two? ... or three?? 
Better use the zero. 

The columns in binary numbers are just like the signal 
lines in a computer. In theory, the columns go on forever 
—and so do the numbers. Regardless of the base you are in, 
you can keep writing numbers forever! But wait! І just said 
that signal lines are usually groups of 4,8 , or 16. If signal 
lines are the same as columns, then there is a limit to the 
Size of number a computer can understand. How big of a 
number can you use? 

To find out, raise the base to the same power as the num- 
ber of positions you have. On chart 1 when we used two 
lines, that was 2 to the 2nd power, or 4 codes or numbers. 


With 4 lines, there are 16 (2 to the 4th); with 8 there are 
256; and with 16 lines there are 65536. 

The last code on the chart is 1111, which in decimal is 
15. | said you could get 16 numbers with four lines, so 
where is the last number? Don't forget to count 0! 0 thru 
15 is sixteen numbers, 0 thru 255 is 256 numbers, and so 
on. 

There are other bases, of course. The numbers marked 
hexadecimal are from a base with 16 digits—the normal 10 
digits from O to 9, plus the letters A to Р. Use them just 
like any other digits. For instance, on the chart, 1111 Біпа- 
ry is 15 decimal and F in hexadecimal (hex for short). The 
next number in hex is 10; in decimal it is 16; and in binary 
you have to add a new position (sixteens) and write 10000. 

You can always add as many zeros to the front of a 
number as you want without changing it. However, if you 
make a binary number divisible into groups of four an in- 
teresting thing happens: Each group of four can represent 
16 codes or numbers. Since that is exactly the number of 
digits in the hex number system, you can substitute! This 
makes long binary numbers much easier to read, and doesn't 
change their value at all. 

Try a few yourself. They're easy! 


Hardware 


The TMS9900 is called a 16-bit CPU (central processing 
unit). This means that when it “fetches” an instruction 
from memory, it gets 16 bits in parallel. And when it reads 
or writes data this is usually done in groups of 16 bits too. 
(Іп the TI-99/4, however, this 16-bit group is converted in- 
to an 8-bit data bus—Ed.| You may hear the term "word" 
used for 16 bits. If you are talking about a 16 bit machine, 
the term is correct. But remember, if you are talking about 
an 8-bit CPU, 8 bits (or byte) is a word; if the CPU is 32 
bits, the word is 32 bits. 

It is only necessary for a programmer to know about 
two kinds of memory. Random-access memory (RAM), 
sometimes called read/write memory, is what stores the 
user's program, data, etc. The user or the computer can 
read or write in it. The memory location is chosen by the 
lines on the bus called address lines. The data that is being 


read or written appears on the data bus. 
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1 0000 
0001 0092 
000) 0009 

1 2 


Break into groups of 4. 


Binary number with 5 positions. Equal to 10 HEX. 
Fill to 8 positions by adding zeros to front. 


Give each group the proper HEX digit {see chart 2) 


10 is the HEX value for 10,000 binary. 


==== ——À 
1 
1041 ЯЯ 18 BINARY 181 8118 1811 4811 8181 1188 9188 8114 8118 
8 2 HEX D 6 8 5 с 4 т 6 
Ф Ф Ф ж” 
о I - 
Ed 
1 $119 BINARY ЕУ 
VALUES М " “ " 
øgi 8118 p^ % % 
1 6 НЕХ 
| POSITIONS a 4 3 2 1 
Chart 3 


Read-only memory (ROM) comes in many varieties and 
works just like RAM except for one thing—it can't be writ- 
ten to. If you tell it to, the computer will go through the 
motions of writing, but it doesn't work. The old data is still 
there. 

Inside of the CPU there are a few memory locations that 
are not addressed by the address bus. The chip itself knows 
where they are. These are called registers. All machine 
language and assembly language programming involves ma- 
nipulating the data in these registers, because that is all that 
the computer really can do! 


How many registers and how big they are varies widely. 
The chip manufacturer usually labels the registers and de- 
cides on a short code, called an operation code, for each of 
the register manipulations that the chip can do. An assembler 
is a program that reads these op-codes and writes them into 
memory in thebinary form that the CPU understands. When 
you write a program using these op-codes you are writing in 
assembly language. И you write your own assembler you 
can devise your own op-codes. But since the manufacturer 
usually writes опе, it is best to use theirs to avoid confusion. 

About the only thing all CPUs have in common is a regis- 


ж Game Programs ж 
for the TI-99/4 


Blackjack — the casino winner 

* Craps — a sure bet for fun 
Hangman — the favorite word stumper 

* Hidden Numbers — builds up your “concentration” 
Peg Jump — а “HI-Q” strategy puzzle 

* NIM — the classic challenge 

* Barrier — enjoy "TWIXT" or “BRIDG-IT” 
Scrambled Letters — alphabet arrangement game 


* Joysticks Required 


All programs on cassette. 
Full written instructions included. 


Regular Price : $12.95 each game 


Cay Special Price (when ordered from this ad): 
Only $10 each postpaid; 


Any 3 for $25 postpaid. 
Or write for descriptive literature from: 
Hall Software Co. 


P.O. Box 1736 
Anderson, IN 46014 


50 99%er Magazine May/June 1981 


[Kes WIE 
I 
Loe "ELI 


WORKING 
OVERTIME 


APPLICATIONS WHICH SAVE TIME 
Payroll, Word Processing, Accounting & 
Financial Management, Educational 
Administration, Legal, Medical & 
Dental Systems 
Check your Local Dealer or Contact: 


Charles Mann & Associates 
7594 San Remo Trail 
Yucca Valley, Ca. 92284 
(714) 365-9718 
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INSTRUCTION REGISTER 
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MEMORY 


2 Chart 4 
ers | 


ter called the program counter (PC). The address bus is just 
an extension of the PC, Each bit of the Program counter is, 
in effect, connected to one signal line of the address bus. 
Since the TMS9900 chip was designed especially for dedi- 
cated control purposes (e.g., production line inspection or 
phone switching) where the program is always in ROM—and 
Since at that time most ROMs were made for 8-bit com- 
puters—the address bus of the 9900 is a little unusual. 

The bitsof the PC allow the chip to address 65536 blocks 
of memory. The blocks could be any size, but as І said, 
most ROMs were in blocks of 8 because most computers 
had 8-bit data buses. The PC in the 9900 has 16 bits. These 


are labeled 0-15, from ( 
(MSB) to least significar 
15 address lines? Follow 


left to right) most significant bit 
it bit (LSB). Why are there only 
on Chart 4 as we go along. 


parameter it “fetches” so that it points to the next memory 
byte. But the 9900 needs 16 bits instead of the 8 available 
at each location in most ROMs. So the 9900 has two dif- 
ferent “fetch” cycles: It reads the byte indicated by the PC 
on the first cycle, "hooks" the next byte to it on the second 
cycle, then increments the PC by two, To the user this all , 
appears as опе fetch, except that the PC is incremented by й 
two instead of by one as expected. By eliminating the last и 
bit, however, the address line appears to step normally, The 
drawback is that you can only address 32767 words. It’s 
still 65536 bytes though. aq й 


In the next issue, we will begin using assembler instruc- 


Normally the PC increments after each instruction and/or 


tions as we examine additional registers, addressing modes, 
and interrupts. 


ЖЖ Ti-99/4 SOFTWARE ЖЖ 


TEXT EDITOR $99 


ТЕХТ/99 - Allows entry, editing, 
disk or cassette Storage and print- 
ing of your written text. Upper & 
lower case. Word oriented for 
fullest editing freedom: change. 
insert, delete or move. Chains files 
for long documents. {Manual 
$10.) 


PERSPECTIVE PLOTTING $199 


DRAW/99 - For architects, en- 
gineers, artists. True perspective 
ог axonometric line drawings of 
any object you enter. Drives 
Mauro Eng. MP-250 plotter (11-in 
paper, about $800), (Manual 520.) 


NAVAL ARCHITECTURE 


99/4 programs for hull design, 
hydrostatics, performance апа 
most marine design calculations. 
Inquire. 


LETCHER OFFSHORE DESIGN 
РО. Box 104, Southwest Harbor, Maine 04679 
Tel. 207-244-7347 


THE MICRO HOUSE 
Complete ТІ-99/4 Line 


; Di Pri 
RINGWRAITH'S LAIR зі Ж 


A fantasy game ої 
high adventure! 
$24.95 


For catalog write 


Px 1586 So. Citrus 
(ӨЗ Escondido CA. ©) 


ZA 92027 А 


CN 
“ы 


99/4 Console 8550 
Disk Drive 400 
Disk Drive Controller 235 
RS232 Interface 175 
Epson MX-80 printer 630 
(with serial board & Cable) 


For complete price list write: 


THE MICRO HOUSE 
527 Simonet Street 
Green Bay, WI 54301 


Tel. (414) 432-2871 
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What Is UCSD Pascal™ 
And Why Is Everybody 
Talking About It? 


By Gary M. Kaplan 


ou can hardly pick up a computer 
Y publication, or attend a computer 

conference or fair these days with- 
out being inundated with mention of 
UCSD Pascal. To understand what all 
the fuss is about, you must first know 
something of what is meant by “рогіа- 
bility," and understand the concept of 
“pseudocode,” and its relation to the 
“P-machine.” 


Portability, Pseudocode, and 
P-Machines 


Let’s start by assuming that you al- 
ready know that Pascal is a structured, 
high-level, compiled language (just as TI 
BASIC is a high-level interpreted lan- 
guage). In this article we won't go into 
the theory of compilers, interpreters, or 
the structure of Pascal as a computer 
anguage; we'll save this for future 
issues. For right now, let's imagine 
that your friend has written a really 
great Pascal compiler and operating 
system in his native 6502 assembly 
anguage for his Apple computer. You'd 
like to move it to your fully-configured 
T1-99/4 which has a TMS9900 micro- 
processor, What are your options? Sure, 
you could always recode the Pascal sys- 
tem for your 9900 (assuming you had a 
9900 assembler), but it would probably 
be almost as much work as starting from 
scratch. How about first writing a 6502 
simulation program for your 9900 and 
letting it re-write all the 6502 code? But 
even if you do this, the extra layer in 
between will result in a loss of speed and 
a greater memory overhead. This is what 
the microcomputer community has been 
up against—virtually no “portability” in 
moving languages or applications soft- 
ware from one system to another with- 
out a major re-working of the code. 

Now let's design a hypothetical pro- 
cessor to provide a convenient "home" 
for Pascal. We'll give it built-in instruc- 
tions for doing the type of things that 
the Pascal language likes to do. Let's call 
this pseudomachine a “Р-тасһіпе” for 
short, and configure it to be a simple, 
idealized stack computer that uses 
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"P-code"—the native language or ma- 
chine code for the P-machine. 

Great, but where do we go from 

here? What's the use of a P-machine, 
and how does it contribute to software 
portability? Must we throw all existing 
hardware and software out, and start 
over giving everyone P-machines? Ob- 
viously not. Rather, consider what 
would happen if we could eliminate the 
differences between the instruction rep- 
ertoires of specific microprocessors, so 
that they all execute the identical 
P-code. Once an emulator for each CPU 
is written (in its native assembly lan- 
guage), one of the largest obstacles to 
portability would be overcome: Soft- 
ware could be written on different com- 
puters in a high-level language such as 
Pascal, then compiled to P-code, and 
finally "interpreted" for each specific 
CPU. Since the P-code would be univer- 
sal, one program written on, say, an 
Apple could be theoretically run (if it 
consisted entirely of P-code) without 
modification, on а ТІ-99/4, Score one 
for portability! 
This is, in effect, what has been done 
in the UCSD Software System. All high- 
level languages in this system—only one 
of which is Pascal—are compiled into 
P-code. One way of looking at it is that 
the system software is not portable at 
all, because it is always executed on a 
P-machine. The portability is provided 
by a P-machine emulator for each host. 
So when you think of a TMS9900-based 
system running Pascal, it is really run- 
ning a simulation of a computer which 
is running Pascal object programs. 


Speed vs Space : A Tradeoff 


What price do we pay for the benefit 
of portability? The detour through a 
P-machine often produces slower execu- 
tion than would native code. But raw 
execution speed is often overshadowed 
by P-code being considerably smaller 
than the corresponding native code—al- 
lowing the available memory to store a 
more capable program. And if a pro- 
gram can be represented with P-code 


that fits entirely into available memory, 
but using native code requires extensive 
overlaying, then the P-code version will 
actually run faster! 

For best performance, it is desirable 
to optimize some portions of a program 
for space, and others for speed. Since 
the UCSD Pascal System provides com- 
munication between an assembly lan- 
guage routine and a Pascal host program, 
it is possible (with some reduction in 
portability) to code time-critical rou- 
tines (usually less than 10% of a pro- 
gram) directly in assembly language. 
The low-level assembly routine can re- 
quest access to host program global 
variables and constants, and can also 
allocate its own global storage space. 

А project is underway at SofTech 
Microsystems (the firm responsible for 
the licensing and maintenance of the 
UCSD Pascal System) to alleviate many 
of the performance drawbacks of P-code 
(e.g., speed) without sacrificing portabil- 
ity. Code generators will translate time- 
critical procedures into native code 
through an optional step in the compila- 
tion process. A code generator will take 
a complete P-code program as input, 
and produce, as output, a mixture of 
unmodified P-code and translated native 
code procedures. Programs can then be 
written and maintained entirely іп 
Pascal, with the P-code object version 
still completely portable. A prototype 
code generator for the TMS9900 
demonstrated that improvement in 
execution performance compared to in- 
terpretative execution has been around 
a factor of 15! And if we take into ac- 
count that translated native code for the 
9900 is about 50% larger than the corre- 
sponding P-code, the improvement is 
indeed significant. 

The Operating System 

UCSD Pascal is not only a language 
compiler, but a complete operating sys- 
tem with utilities and libraries. In addi- 
tion to the Compiler, you have a screen- 
oriented Editor and a File Manager (or 
"Filer"). The design philosophy behind 


datasouth announces... 


THE TOTAL 
PRINTER PACKAGE! 


The DS180 matrix printer provides the total package of 
performance features and reliability required for applica- 
tions such as CRT slave copy, remote terminal networks 
and smal! to mid-range systems. Not a "hobby-grade" 
printer, the 05180 is a real workhorse designed to 
handle your most demanding printer requirements. And 
pricing on the DS180 is hundreds of dollars below 
competitive units. 

High Speed Printing — Bidirectional, iagic-seeking 
printing at 180 cps offers throughput of over 200 10m 
on average text. A 9-wire printhead life-tested at 650 
million characters generates a 9x7 matrix with true 
lower case descenders and underlining 

Non-volatile Format Retention —a unique programming 
keypad featuring a non-volatile memory allows the user 
to configure the 05180 for virtually any application. Top 
of form, horizontal and vertical tabs, perforation skip- 
over, communications parameters and many other 
features my be programmed and stored from the key- 
pad. When your system is powered down, the format is 
retained in memory. The 05180 even remembers the 


line where you stopped printing. There is no need to 
reset the top of form, margins, baud rate, etc. .it's all 
stored in the memory. If you need to reconfigure for 
another application, simply toad a new format into 

the memory. 

Communications Versatility — The 05180 offers three 
interfaces including 85232, current loop and 8-bit 
parallel. Baud rates from 110-9600 may be selected. A 
1K buffer and X-on, X-off handshaking ensure 

optimum throughput. 

Forms Handling Flexibility — Adjustable tractors accom- 
modate forms from 3"-15". The adjustable head can 
print 6-part forms crisply and clearly making the 05180 
ideal for printing multipart invoices and shipping docu- 
ments. Forms can be fed from the front or the bottom. 

If you would like more information on how the 051805 
low-cost total printer package can fill your application, 
give us a call at Datasouth. The DS180 is available for 
30-day delivery from our sales/service distributors 
throughout the U.S. 


datasouth 


computer corporation 


4740 Dwight Evans Road • Charlotte, North Carolina 28210 е 704/523-8500 


UCSD Pascal was to keep users continu- 
ously informed about the state of the 
system and the options available in that 
state. This is done with a prompt line 
that allows users to select options by 
typing single-character commands. 

The screen orientation of the Editor 
means that you'll be doing lots of pag- 
ing instead of scrolling. The editor 
positions a cursor into the text file be- 
ing edited and surrounds it with a 
“window” into that area of the file. 
When you look at the display screen, 
you are peering into this window. To 
modify text you simply move the cursor 


to the place where the change is desired, 
and indicate the change. Commands are 
provided for cursor movement, finding 
and replacing patterns of text, making 
insertions and deletions, and copying 
text from elsewhere and moving it to 
any position indicated by the cursor. In 
addition to the powerful text editing 
commands, special facilities are pro- 
vided for processing documents—e.g., 
user-specified left and right margins, and 
auto-indenting to encourage the writing 
of structured programs. In microcom- 
puter systems without an 80-column 
display, horizontal scrolling allows users 


to move the text window left and right 
to view the entire Pascal page. 

When you enter the Filer, you have 
access to another complete set of com- 
mands: (1) housekeeping commands such 
as listing directories, compacting files on 
a disk, and testing disks for bad sectors; 
plus (2) program execution and file 
manipulation commands for execut- 
ing named object programs, invoking 
(with shortcuts) important system pro- 
grams, designating files for removal, and 
for renaming or transferring among on- 
line devices. 

The Pascal Compiler translates Pascal 
programs from a humanly readable text 
form (source code saved on disk by the 
Editor) into P-code form (object codc) 
which is saved on disks for future execu- 
tion. The Compiler is designed to trans- 
late the entire contents of a text file in 
one pass. But unlike the Editor and 
Filer, it has hardly any interactive com- 
mands. You can, however, change cer- 
tain controls ("directives") which govern 
the way in which the Compiler does its 
work. 


Error Handling 


A big difference between an inter- 
preted language (such as BASIC) and a 
compiled language (such as Pascal) is 
demonstrated in the way syntax and 
run-time errors are handled: 1f the Com- 
piler finds a syntax error, it halts and 
displays an error message (if you've set 
it to automatically return to the Editor), 
or screen prints a progress display con- 
taining copies of the line (and previous 
linc) where the program error is found, 
as well as the coded number of the syn- 
tax error. You can fix the error (by re- 
turning to the Editor) or attempt to 
compile the rest of the program. In 
some less drastic conditions, the pro- 
gram will, in fact, compile all the way to 
the end without the Compiler losing its 
way. 

Run-time (execution) errors also 
cause all the action to stop. A threc-line 
error message tells you the type of error, 
the segment and block where it oc- 
curred, and how far from the beginning 
of the block (which you convert to the 
actual line of code). In simple cases, this 
will be all the help that's needed to pin- 
point the error; in more complex Cases, 
you'll have to insert WRITELN state- 
ments (the equivalent of PRINT) to 
determine the values of variables before 
the program blew up. (There's no con- 
venient. BREAK statement as in ТІ 
BASIC.) 


Additional Language Support 


The UCSD Pascal System does, in 
fact, support additional compiled lan- 
guages. At the present, FORTRAN-77 
and BASIC Compiler are supported di- 
rectly by SofTech Microsystems (Micro- 
Focus CIS COBOL is also presently run- 
ning under the UCSD  P-System). 
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5280 PRINT “YOU HAVE DEFEATED THE ALIENS” 3940 21-21114 
| 5290 PRINT "AND SAVED THE EARTH FROM" 5950 IF 2145 THEN 4120 
| 3300 PRINT “ETERNAL SLAVERY" 3960 250 THEN 4120 
5510 CALL SOUND (200, 440, 2) 5970 CALL SOUND (20,1480, 2) 


SofTech also has а Cross-Assemblers 
Package (a complete set of native code 
generating cross assemblers for the 280, 
8080, Z8, PDP-11/LSI-11, 6502, 6800, 
6809, and 9900 microprocessors) that 
allows programming on the host ma- 
chine of your choice, for the object ma- 
chine of your choice. Think of the 
possibilities . . . 


UCSD Pascal 
Community 


Besides being a powerful tool for 
software developers, UCSD Pascal is of 
great importance to the ТІ-99/4 com- 
munity. Texas Instruments has indi- 
cated that there is to be a user's version 


and the ТІ-99/4 


of Pascal in addition to the UCSD Pascal 
Development System. [See related arti- 
cle that follows.] Under this two-tier 
system, users will not have to buy all 
the software and hardware that software 
developers need to write and debug pro- 
grams. The final configuration and price 
of the user's system (scheduled for re- 
lease toward the end of 1981) has not 
yet been decided. The only detail made 
public at this time is that the P-code 
interpretation will be done by a "Р-Соде 
Box" accessory containing one type of 
read-only memory (an undisclosed 
amount). 

This means that а ТІ-99/4 user will 
be able to run some very sophisticated 


and powerful applications software 
with only a minimal investment in the 
svstem hardware and software. To put 
this into proper perspective, it's quite 
possible that someone interested in only 
running (and not writing) UCSD Pascal 
applications programs will have to spend 
about three times (!) the cost of a тіпі- 
mum Т1-99/4 user-Pascal system if he 
instead chooses UCSD Pascal-compatible 
hardware from another microcomputer 
manufacturer. This is quite a premium 
to pay if a user won't be writing his own 
software. Needless to say, this could 
turn out to be quite a marketing coup 
for Texas Instruments. 


UCSD Pascal is a Trademark of the Regents of 
the University of California. 


3270 GOTO 5410 


] 3320 CALL SOUND (500, 740,2) 
| 3330 CALL SOUND (500, 1047,2) 
3340 PRINT “YOUR SCORE I 
3350 GOTO 4570 

3360 NEXT X3 


3470 CALL KEY(O,K,ST) 


Invasion from Space, continued from p. 45 


80 NEXT 
90 CALL 


POINTS 4000 GOTO 


4010 CALL 
4020 CALL 


2570 NEXT X2 4030 CHECK FOR TYPE OF 
3380 IF M2<30 THEN 3400 4040 HIT BY OPERATOR 
3390 мані 4050 THEN 1820 
3400 RETURN 4060 THEN 1900 
3410 PRINT :: 4070 THEN 1980 
3420 PRINT "DO YOU WISH TO PLAY AGAIN" 4080 THEN 4330 
$450 PRINT 4090 IF CH=108 THEN 4400 
і 3440 PRINT “IF SO TYPE ""Y"" TO CONTINUE" 4100 IF CH-109 THEN 4470 
і 3450 PRINT 4110 IF CH=112 THEN 2080 
! 3460 PRINT "TYPE ""N"" TO STOP" 4120 CALL VCHAR(Z,Z1-24,22) 


4130 RETURN 


2 

VCHAR (2+1.21-74.52) 
4150 

VCHAR (C2, 21,22) 

SOUND (200, 110,2, 6,2) 


3480 IF ST=0 THEN 5470 4140 REM SET UP VARIABLES 
3490 IF K-78 THEN 4570 4150 REM TO FIRE OPERATOR 
3500 IF каве THEN 3540 4150 REM MISSLES IN ONE OF 
3510 GOTO 3470 4170 REM THREE DIRECTIONS 
3520 REM SET UP VARIABLES 4180 22--2 
5550 REM FOR NEXT GAME 4190 Z3=121 Н 
3540 FOR X=1 то 50 4200 14=-1 i 
| 5550 М(1,4) 20 4210 БОТО 3810 
3560 MS, x) =0 4220 22-2 t 
| 5570 M(5,X)=0 4230 23-122 і 
5580 POUINTS-O 4240 14-21 ] 
3590 x 4250 GOTO 3810 i 
| 3600 4260 12-0 | 
3610 4270 75=120 { 
3620 GOTO 130 4280 24-0 ] 
3430 REM DISPLAY SCORE 290 GOTO 5810 
3540 POzPOINTS 4200 REM ENEMY MISSLES 
5650 IF POINTS>=0 THEN 5680 4310 REM DESTROYED BY 
3660 POINTS=POINTS# (-1) 4320 REM THE OPERATOR | 
: 3570 CALL УСНАЯ(1,9,45) 4550 FOR J=! ТО 30 
заво =INT (PGINTS/1000) 4340 IF M(1,J)<>Z THEN 4390 
3690 МТ (РОІМТ5/ 100) -8С1810 4350 IF M(2,J)<>Z1 THEN 4590 3 
2700 МТ (РОІМТ5/ 10) -((SC11100) -(5С2410)) 4360 M(t1.J) 4 
| 3710 5Са=РО1МТ5-((5С1#%1000) +‹5С2#100) +(5С5#10›› 4370 РО1МТ5=РО1МТ8+5 
5720 IF PO<O THEN 3740 4380 RETURN 
5750 CALL VCHAR(1,9,ASC(STRS(SC1))?) 4399 NEXT J 
] 3740 CALL VCHAR(1,10,ASC(STRS(SC2))) 4400 FOR J=1 TO 50 4 
5750 CALL УСНАЯ (1,11, ASE (STR$(SC3) )) 4410 IF M(3,J)<>Z THEN 4460 Lt 4 
5760 CALL VCHAR(1,12,ASC(STRS(SC4))) 4420 IF M(4,J)42Z21 THEN 4460 A 
3770 POINTS=FO 4430 М(5.Ј)=0 b: 
| 3780 RETURN 4440 POINTS=POINTS+5 E. 
| 5790 ҺЕМ MOVE OPERATORS 4450 RETURN P 
3800 REM MISSLE 4460 NEXT J Л 
| 3810 71-Р2%72 4470 FOR J=1 TO 50 
2820 CALL БСНАК (25,Р2+24,СН) 4480 IF М(5,2)627 THEN 4530 
3830 IF CH=32 THEN 3880 4490 IF М(6,20<>21 THEN 4550 
3840 CALL VCHAR(22,21424,32) 4500 M(S,J)=0 
3850 2223 4510 POINTS=POINTS+5 
3860 21-P2«24 4520 RETURN 
3870 GOTO 4010 4530 NEXT J 
3880 CALL УСНАН(25.Р2%24,25) 4540 RETURN po 
3890 FOR Z-22 TO 2 STEP -1 4550 REM END ОЕ PROGRAM 
3900 CALL GCHAR(Z,Z1,CH) 4560 REM MESSAGE ; 
i ! 3910 CALL VCHAR(*1,21-24,32) 4570 PRINT "YOU COULDN'T FIGHT YOUR" 
3920 CALL VCHAR(Z,Z1,23) а5во PRINT “WAY OUT OF A PAPER BAG. 
] 5920 IF СН>52 THEN 4010 4590 END 
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THIRD-PARTY SOFTWARE 
DEVELOPMENT 


id you miss out on buying gold at 
ВЕ an ounce ...or ignore those 

first few McDonald’s franchises 
that "nobody seemed to want”... or 
perhaps, throw out your old comic 
book collection (dating back to the first 
Superman) because you needed thc 
space? Well-now's your chance to get 
even. The software business is booming 
and the decade of the 80s will provide 
unprecedented opportunities for those 
with enough foresight to get in on the 
ground floor. 

The microcomputer industry is very 
young. If as little as four years ago you 
started tinkering with hardware and soft- 
ware to sell, you're already considered 
to be an "oldtimer!" But four years, in 
a dynamic industry such as this, is a 
long time. Much of what has occurred 
over this period was not expected to 
happen so quickly. What the industry 
will be like four years hence—when 
consumers start buying microcomputers 
like they're presently buying microwave 
ovens—is anybody's guess. One thing, 
however, is certain: Severa/ million 
microcomputer owners are going to 
need software, 

Where will all this software originate 
from? Who will be supplying it to the 
end users? What machines will be the 
most popular with these non-hobbyist, 
applications-oriented consumers? Soft- 
ware developers with an eye on this 
eventual mass market can't help but 
notice how the present hardware from 
Texas Instruments has been “human 
engineered" to appeal to this group 
—much more so than the present breed 
of popular hobbyist computers. Support- 
ing this TI product line would therefore 
Seem to be as good a bet as any in the 
marketing scramble ahead . . . 

With this in mind, let's take a brief 
look at what Texas Instruments is pre- 
sently offering to third-party software 
developers. The first question that 
Comes to any developer's mind concerns 
programming languages. Which ones arc 
presently available for users to run, and 
which will be forthcoming? There's no 
need to discuss TI BASIC here; it's been 
around since the inception of the ТІ- 
99/4, and has been the only language 


SYSTEMS 


that the sma// software developer could 
utilize. І am predicting, however, that 
more developers will turn to the new 
Extended BASIC because of its greater 
capabilities and protection feature. An 
explanation of Extended BASIC in 
relation to software development is 
covered in a separate article in this issue. 


UCSD Pascal™ 


Software Development System 


This brings us to the UCSD PascalTM 
Development System, which, as we go 
to press, is being released with UCSD 
Pascal Version 4.0 (as upgraded from its 
predecessor Version 2.0 by SofTech Mi- 
crosystems, the San Diego firm respon- 
sible for maintaining and licensing the 
UCSD software). As presently sold by 
Texas Instruments, the System allows 
you to program in UCSD Pascal and 
TMS9900 assembly language. With this 
system, you have the capability to ac- 
cess hardware through assembly subpro- 
grams, and take advantage of all machine 
capabilities such as sprites, sound, and 
speech. Developers who program in 
UCSD Pascal (the UCSD Pascal System 
includes UCSD Pascal as one of its lan- 
guages) gain the benefit of portability: 
applications programs that can run on 
many different computers (not just 
TI-99/4s) without modification. [See re- 
lated UCSD Pascal article in this issue.] 
And because the development costs of 
these programs may be quickly recouped 
(by selling potentially 50,000 to 100,000 
copies), it becomes unnecessary to sacri- 
fice features or reliability to hold down 
development time and cost. 

The System that Texas Instruments 
is now making available is in a "hybrid" 
form: A “Super Memory Box" contains 
both the necessary expansion RAM for 
editing and compiling Pascal, and the 
extra GRAM (Graphic Random-Access 
Memory) for the P-Code interpreter (af- 
ter downloading from disk). The final 
implementation (available in third-quar- 
ter 1981) will use the expansion 32K 
RAM peripheral and a separate “P-code 
Box" (with itsown resident interpreter). 
The price is higher, however, for the 


By Gary M. Kaplan 


presently available hardware and soft- 
ware (approximately $1,050 for the 
"Super Memory Box" and $900 for the 
software; vs, $400 for the 32K RAM 
peripheral, $600 for the software, and 
as yet, an undetermined amount for the 
"P-Code Box"). In addition to the 
UCSD software, TI provides both im- 
plementations with a run-time package 
of machine-specific utilities. [For a brief 
discussion of TI's forthcoming end-user 
Pascal system, see the last section in this 
issue’s "What Is UCSD Pascal . , . '] 

For software developers interested in 
programming in TMS9900 assembly lan- 
guage, there are some additional consid- 
erations. The UCSD Pascal Development 
System includes a text editor, macro 
assembler, and link-editor. During assem- 
bly a sct of macros facilitates accessing 
specific ТІ-99/4 hardware features (eg, 
the VDP or sound chip). An 1/0 utility 
is available which may be linked with an 
assembly routine to provide access to 
peripherals (e.g., disk drives, RS-232). 
Since assembly language programs must 
be called up through Extended BASIC 
On a user's system, there must be some 
way to convert assembly language ob- 
ject files produced on the UCSD Pascal 
Development System (employing a spe- 
cial disk format) to the format required 
by Extended BASIC. TI, therefore, pro- 
vides a utility to do this conversion. 
[See related article on Extended BASIC 
in this issue. ] 


A Separate Assembler 

If your main interest is assembly 
language programming and you don’t 
feel like making the investment in the 
UCSD Pascal software and hardware, 
there will soon be another option, Texas 
instruments has announced that a 
TMS9900 assembler will soon be forth- 
coming. No additional details have been 
released. Whether it is only a simple 
line-by-line assembler, or a more power- 
ful package (complete with text editor, 
etc.) as in the UCSD System remains to 
be seen. Nevertheless, the fact that ТІ is 
releasing a separate assembler (CAL Lable 
through Extended BASIC) ís a symbolic 
(no pun intended) gesture of great signi- 
ficance: It demonstrates a shift in policy 
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Power - Line Problems 


In Personal Computers 


Ithough glitches, crashes, errors, 
А" printouts, memory loss, and 

other forms of erratic microcom- 
puter operation are usually blamed on 
software and hardware, most of these 
annoying problems actually come to 
you courtesy of your ordinary 120 Volt 
powerline! These problems are directly 
traceable to three general causes: (1) 
processor-memory-peripheral interac- 
tion, (2) power line noise/hash, and (3) 
transient voltage surges. Fortunately, 
serious computer users don’t have to 
live with these problems, since many 
types of corrective devices are available. 


Powerline Coupling 


The fact that microcomputer systems 
are so easy to hook-up—just plug the 
computer and peripherals into the wall 
socket, and connect the components 
with a few convenient male/female pre- 
assembled cables—makes them suscepti- 
ble to powerline coupling and the device 
interaction that results. Multiple-socket 
power strips that are integrated with 
КЕ! (radio-frequency interference) fil- 
ters will effectively isolate the computer 
and peripherals from each other and 
from the power line—thus providing a 
convenient solution to the problem. 


Hash 


Hash is another problem altogether. 
When your favorite space-war game gets 
fouled up by ‘‘glitches,” or your pre- 
viously-proven-to-be-faultless | program 
"blows up" or creates erroneous print- 


out, externally created hash is the prob- 
able cause. Elimination of hash at the 
source is the most desirable solution. 
But with hundreds of potential sources 
(arcing in tools, motors, appliances, and 
other small electrical devices, plus loose, 
defective, or corroded light sockets, wall 
sockets, line-cord plugs, or wire connec- 
tions), pinpointing the offender is often 
difficult. That's when hash filters are 
most effective. They often can complete- 
ly eliminate the interference. 

An alternate approach to the hash 
problem is first to make certain that all 
equipment covers and shields supplied 
by thc manufacturer are securely fas- 
tened in place. If that doesn’t work, you 
might try building and installing your 
own shield. Also don't forget to make 
sure that you have an adequate ground- 
ing system with direct ties to a good 
ground rather than ground loops (which 
often provide a home for system hum 
that can induce glitches). 


Transient Voltage Surges 


Transient voltage surges (transients) 
are certainly not friends of microcom- 
puter circuitry. Semiconductor compo- 
nents are easily damaged by these mo- 
mentary spikes—often 5 or 10 times the 
normal AC line voltage. And [EEE stu- 
dies indicate that some transients have 
pulses up to 5,600 volts! 

Common causes of destructive power- 
line transients include (1) demand power 
load switching by utility companies, (2) 
nearby lightning strikes, (3) static dis- 
charge, and (4) on/off switching of in- 
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ductive motors, power supplies, air con- 
ditioning and refrigeration units. Any of 
these can cause a Differential Mode 
powerline surge—one in which short 
surges of extremely high voltage are de- 
veloped between the AC lines. Anything 
connected to the AC lines will get a 
dose of this damaging voltage. The re- 
sulting “domino effect" could wipe out 
large sections of memory of a micro- 
computer. 

A Common Mode surge occurs when 
both AC lines are brought to a very high 
voltage—a situation usually caused only 
by lightning. This high voltage may 
cause arcing between conductors and 
ground, destroying the insulation of 
power transformers (rendering the units 
worthless) and cables. Damage to 
switches and controls is also a frequent 
occurrence in this situation. 

Besides the surge damages that are 
immediate and permanent, there are 
some harder-to-detect damages as well: 
performance characteristics and short- 
ened life-spans. These damages can be 
the most irritating since equipment will 
require repeated servicing and will often 
seem to be falling apart. 


Fortunately, a large measure of surge 
protection is possible with clamping de- 
vices that can be placed across the AC 
line and between each AC line and 
ground. These devices are frequently 
built into special AC line cords, and 
thus, like the other protective devices 
mentioned, can be attached without 
altering any equipment. Ф 


Third-Party, continued 


and signifies a new willingness to allow 
outsiders to take fuller advantage of the 
powerful hardware residing the T1-99/4 
product line. 


Debugging Assembly Language 


Software development in assembly 
anguage usually involves a great deal 
of debugging. To aid in this time-con- 
suming process, most programmers de- 
pend heavily on debug utilities resident 
in monitors. So if you are using the 
UCSD Pascal Development System, 
Texas Instruments will presently modify 
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your ТІ-99/4 console and RS-232 inter- 
face (for approximately $250) to pro- 
vide the necessary hardware and soft- 
ware traps to send the information to an 
external CRT or printer terminal. (The 
ten commands and eight utilities of the 
TiBUG monitor are then at your dispo- 
sal.) TI has also indicated that in third- 
quarter 1981, it will sell developers the 
modified console and RS-232 at the reg- 
ular retail prices. The plans for debugging 
support of the separate 9900 assembler 
haven't as yet been disclosed. 


In Part 2 of this series on Third-Party 


Software Development Systems (in the 
July/August issue), we will look at GPL 
as а development language, consider the 
options in bringing up other languages 
to run under the UCSD Pascal Software 
Development System, and examine the 
technical and marketing considerations 
in the choice of programming media 
—cassettes, diskettes, and Command 
Modules. And in related articles in forth- 
coming issues, we'll explore other sys- 
tems for programming and producing 
firmware in 9900 assembly language. 


ї 
| 
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LOGO: 


A Computer Language as а 


Learning Environment 


By Daniel H. Watt Ph.D. 


For many years the work of the MIT LOGO Group has been supported primari- 
ly by the National Science Foundation, and secondarily by a number of other 
public and private agencies. The Texas Instruments company has provided direct 
support for the technical development of TI LOGO. The author wishes to ас- 
knowledge the support of these agencies, and of the Public Schools of Brookline, 
Massachusetts. The opinions expressed here are those of the author, and not the 
responsibility of any of the supporting agencies. 


puter language designed for educa- 

tional purposes especially as a pro- 
gramming language suitable for young 
children—will soon be available on Texas 
Instruments ТІ-99/4 Home Computers. 
For more than a dozen years, the LOGO 
language and related computer program- 
ming activities have been developed and 
tested by the LOGO Group at the Massa- 
chusetts Institute of Technology. Under 
the leadership of MIT Professor Seymour 
Papert, LOGO activities have been used 
with children as young as nursery school 
age, with MIT undergraduates, and with 
many students of all ages in between. 
The philosophy of LOGO's developers 
has been: “Мо threshhold, no ceiling.” 
A beginner can make the computer do 
something meaningful and interesting in 
the very first programming session. Yet, 
the other extreme, LOGO is suitable for 
extremely advanced programming pro- 
jects. 

The philosophy of LOGO has been 
derived primarily from two sources: The 
developmental theories of the late Swiss 
psychologist, Jean Piaget (with whom 
Seymour Papert worked for several years 
before coming to MIT), and ideas from 
a modern scientific field called Artificial 
Intelligence. From Piaget comes the idea 
of creating learning environments іп 
which most of what children learn can 
occur naturally—in the same way chil- 
dren learn to speak their native language, 
walk or run, and play ball. From Artifi- 
cial Intelligence come ideas about ways 
to use programming languages to aid 
thinking and problem solving. ` Pro- 
gramming a computer in LOGO is seen 
as the act of teaching the computer a 
set of new commands, based on what it 
already knows how to do. Each user is, 
in effect, creating his or her own com- 
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puter language, to suit his or her own 
purposes. Readers interested in learning 
more about these ideas should read 
Mindstorms, a recent book by Seymour 
Papert, inwhich he develops and extends 
his vision of the relationship between 
computers and learning that led to the 
development of LOGO. [See excerpts in 
this issue—Ed.] 

LOGO activities are designed to allow 
use of the computer in a way that is per- 
sonally meaningful to the user. Activi- 
ties developed by the MIT LOGO Group 
have included using a computer to con- 
trol the behavior of a robot turtle, draw 
pictures and explore geometric environ- 
ments on a ТУ screen, create computer 
animations, invent interactive computer 
games, compose, arrange and play music, 
and produce "poetry." The best known 
LOGO activity is usinga simulated robot 
turtle on a TV screen to produce geo- 
metric designs and cartoon-like drawings. 
Hundreds of children have learned com- 
puter programming and problem solving 
skills, and developed mathematical ex- 
pertise while writing programs for the 
turtle. 

The LOGO language includes com- 
mands to make the turtle move and 
draw pictures. A student drawing with 
the turtle can make it move around on 
the TV screen, by typing familiar com- 
mands such as FORWARD and BACK 
or RIGHT and LEFT. The information 
beginners need to control the turtle is 
already present in their own body 
knowledge of how to move forward or 
back, and how to turn right and left. 
Programming becomes an extension of 
something a learner already knows— 
rather than something requiring the 
mastery of an elaborate technical lan- 
guage or a complex coordinate system. 
The turtle becomes for the learner, what 
Seymour Papert has called "an object to 
think with." Students using the compu- 


ter as a programming tool become more 
aware of both their own body motion 
and the behavior of the computer. 

The version of LOGO developed col- 
laboratively by Texas Instruments and 
the MIT LOGO Group for the ТІ-99/4, 
includes an entirely new graphics envi- 
ronment called а “Sprites World." 
Sprites are small objects that can move 
rapidly around the screen changing 
shape, color, speed and direction. Large 
numbers of sprites can appear at the 
same time to produce exciting animated 
designs, or to be used as elements in 
programs to create video games. The 
Sprites World promises to be one of the 
most exciting computer based learning 
environments yet invented, because of 
its inherent attraction for so many peo- 
ple and because of the geometric and 
problem solving ideas embedded in it. 


The World of the Turtle 


Let's take a closer look at what ac- 
tually happens when someone learns to 
program a computer using the LOGO 
turtle. The turtle responds to simple 
commands typed at the keyboard: 
FORWARD 100, BACK 50, RIGHT 90, 
LEFT 45, etc. FORWARD 100 moves 
the turtle forward “100 turtle steps," 
drawing a line on the TV screen in the 
process, LEFT 45 makes the turtle ro- 
tate 45 degrees to its own left. People 
learning LOGO find it natural to “iden- 
tify" with the turtle, imagining them- 
selves going through its motions, as it 
carries out a particular task. At the same 
time, controlling the turtle becomes a 
metaphor for controlling the computer 
itself: Like the turtle, the computer 
responds to an ordered series of com- 
mands, and to procedures that are de- 
fined as series of commands. 

The ways in which the actions of the 
turtle can lead to geometric designs, as 


well as the method used to define pro- 
cedures is illustrated in the following 
simple examples. The turtle can draw a 
square by repeating the commands 
FORWARD 100 RIGHT 90 four times. 
A procedure can be defined by choosing 
a name (BOX, for example) and typing 
a series of commands in order, 


TO BOX 

10 FORWARD 100 
20 RIGHT 90 

30 FORWARD 100 
40 RIGHT 90 

50 FORWARD 100 
60 RIGHT 90 

70 FORWARD 100 
80 RIGHT 90 


When the new command, BOX, is 
typed, the turtle immediately draws the 
shape shown in the figure. (The small 
triangle shown in the figure represents 
the turtle by showing its position and 
heading.) A similar procedure, TRI, 
can be defined as follows: 


TO TRI 

10 FORWARD 100 
20 RIGHT 120 

30 FORWARD 100 
40 RIGHT 120 

50 FORWARD 100 
60 RIGHT 120 


A student who has defined procedures 
such as BOX and TRI is beginning to 
“teach the computer” his or her own 
private language. BOX and TRI can now 
be used in the same way as other LOGO 
commands. They can be used to create 
other drawings such as а simple "house" 
or ап abstract geometric “flower.” 


This approach to geometry and pro- 
gramming provides the basis for a rich 
universe of activities known as Turtle 
Geometry, which includes cartoon draw- 
ings, simple and complex geometric de- 
signs, mathematical theory building, and 


computer games. Extensions of Turtle 
Geometry have proven fruitful when 
used with advanced high school students 
or MIT undergraduates. The universe of. 
Turtle Geometry provides a conceptual 
framework for such aspects of mathe- 
matics as the relation between shapes 
and angles, coordinate systems, positive 
and negative numbers, the use of varia- 
bles, symmetry and similarity, and even 
calculus and differential geometry. The 
computer programming involved in be- 
ginning LOGO activities can include 
procedures and subprocedures, the nam- 
ing of procedures and variables, proce- 
dural hierarchy, recursion and iteration, 
the use of conditional logic, and the de- 
velopment of problem solving strategies. 

Within the universe of Turtle Geome- 
try, there is room for different students 
working individually to create their own 
sub-universes or microworlds. They can 
do this with their own limited (but ex- 
pandable) sets of concepts and related 
activities and projects. To teach LOGO 
is really to help learners create, explore, 
and extend their own microworlds. 


Си 


| have used turtle geometry as an 
example of what can be done with 
LOGO because it is casy for a reader to 
visualize the commands and to see how 
they lead to procedures that produce 
the results in the pictures—just as it is 
for young children. Children learning 
LOGO have actually carried out many 
other types of projects as well: moving 
turtles, finding their way around race- 
tracks or mazes, animated cartoons, in- 
teractive computer games such as Nim 
and Tic-Tac-Toe, programs which gen- 
erate sentences or poetry (or even play 
Mad-Libs), and programs to translate 
English into Morse Code, or vice-versa. 
As LOGO becomes available to owners 
of TI-99/4 computers, І hope that these 
pages can be a forum for describing 
your LOGO projects. Since there will 
soon be more LOGO users than ever be- 
fore, we can expect more and different 
LOGO projects to emerge. One of the 
best ways to build the culture of LOGO, 
is for users to share project ideas through 
the pages of magazines such as this. 

Although TI LOGO is a recent entry 
to the LOGO World, a prototype ver- 
sion has already been tested with hun- 
dreds of students between the ages of 
three and nine at the Lamplighter 
School in Dallas, Texas, and by students 
in fifteen elementary and junior high 
schools in New York City. Using the 
Sprites World of animated graphics acti- 
vities, these students are busily creating 
a new universe of LOGO activities, to 
delight and educate a new generation of 
computer users. In an age in which com- 
puters are omnipresent in socicty, and 
in which universal computer literacy is 
a pressing national need, computer-based 
learning environments like LOGO have 
become essential to the process of grow- 
ing up literate in the last decades of the 
twentieth century. У 


Dr. Watt will be leading several! LOGO work- 
shops during the next few months. Contact 
him at Technical Education Research Centers, 
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The Lamplighter LOGO Project 


By Henry Gorman Jr. 


Department of Psychology, Austin College, 
Box 1584, Sherman, TX 75090 


и child is not а vessel to be filled, 
А: а lamp to be lighted.” The 

quote from Alexandrov is on the 
plaque outside the Lamplighter school, 
That sign advises any visitor that the 
school fs very unusual. 

The curriculum at Lamplighter is in- 
dividually tailored to meet the needs 
of each student. Individualization is ap- 
plied in science, language arts, math, dra- 
ma, music, art, French, and physical 
education. The Lamplighter is strongly 
supported by the parents of its students 
and by its alumni, with graduates of 
Lamplighter frequently dropping by to 
see their former teachers. Such alumni 
loyalty might not be considered unusual, 
except that Lamplighter classes begin 
with preschool {age 3) and end with 
fourth grade-level! 

The physical arrangement of the 
school reinforces its approach to learn- 
ing. Classrooms have only three walls; 
the fourth side of each class opens onto 
an airy, bright shared-space. Classrooms 
are clustered around these shared-spaces 
by grade-level. Inside each classroom 
there are tables and chairs for writing 
work and, on one side, a small tiered 
well which is used for many other acti- 
vities (e.g., reading, French, music, or 
story telling). The staff, the facilities, 
the students, and the parents all contri- 
bute to make Lamplighter a very special 
private school. 

Lamplighter has been a leader in the 
use of new technology for learning. Cal- 
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culators, Speak & Spells, Systems 80 
units, and Little Professors are abundant 
throughout the school. Students regular- 
ly use these learning tools and other 
learning games found in the shared- 
spaces, Teachers make extensive use of 
slides, films, video and audio tapes. 
When Mr. Erik Jonsson (co-founder of 
Texas Instruments and Lamplighter 
Board of Directors Chairman and bene- 
actor) first proposed introducing com- 
puters into Lamplighter, his idea was 
well received. Mr. Jonsson had earlier 
been іп contact with Dr. Seymour 
Papert of the Division for Study and 
Research in Education (DSRE) of MIT, 
and found the LOGO language and phi- 
osophy of learning intriguing. Papert's 
initial explanation that LOGO allowed 
students to program computers and not 
vice-versa, enjoyed a favorable reception 
rom the Lamplighter faculty. Later as 
Papert elaborated on the LOGO philoso- 
phy, it became clear that LOGO was 
very much in accord with the practice 
and philosophy of Lamplighter. 

In the fall of 1978, Papert and several 
others from DSRE made a series of pre- 
paratory visits to Lamplighter to arrange 
for the introduction of LOGO to the 
school. The plan was to begin LOGO 
training for first the faculty, and then 
the students by using the Digital LSI-11 
LOGO (in use at the Brookline Massa- 
chusetts project) and later, bring TI 
LOGO into the school as it developed. 

Shortly after the first visit by Papert, 


Lamplighter rented the first of two 
LSI-11’s that were to be used in the ini- 
tial two years of the project. Training 
sessions helped the initial core of Lamp- 
lighter faculty (representing nursery 
school, second grade, third grade, and 
fourth grade) become facile with LOGO, 
This "Computer Group" then began 
working with third and fourth grade 
students. Shortly thereafter, а second 
LSI-11 was rented, and by the end of 
the spring term every third and fourth 
grade student had had at least one hour 
of LOGO instruction on a computer, 
The third and fourth graders consi- 
dered it a treat to work on the computer 
—partly because special activities allowed 
them to miss classes, and partly because 
they genuinely enjoyed LOGO, One stu- 
dent's remark reflects the sentiments of 
many of these pupils. After he had spent 
an hour figuring line lengths, turn an- 
gles, and sections of arcs in order to 
construct a computer picture of a cat, 
he thanked me for "getting out of math 
class," 
In the summer of 1979, the com- 
puter Group was expanded, and two 
workshops were held to freshen the 
teachers’ memories. Subsequently, a 10 
day workshop at MIT introduced the 
teachers to more elaborate LOGO pro- 
gramming and allowed them to partici- 
pate in discussions on the relationships 
between learning and LOGO, Then, as 
the new school year started, the teachers 
were really surprised to discover how 


little the fourth graders had forgotten 
about LOGO. These students generally 
recalled all of the commands they had 
learned three months  earlier—even 
though they had had no contact with 
LOGO in the interim! 

Midway through the fall semester of 
1979, several early prototypes of TI 
LOGO were tested at Lamplighter and 
revised by the MIT LOGO laboratory 
personnel in consultation with Lamp- 
lighter and Texas Instruments. In January 
1980, the pace of computing at Lamp- 
lighter accelerated as an updated version 
of TI LOGO was implemented on the TI 
prototypes. By the end of January, a 
dozen prototypes were in use at Lamp- 
lighter, and very few students continued 
to use the 151-11 LOGO. Most pupils, 
in fact, switched to the TI prototypes 
even though that meant relearning much 
of LOGO, 

In the middle of the spring semester, 
a few more prototypes arrived and all 
the machines were upgraded to a later 
version of Tl-based LOGO. Before the 
school year ended, all of the third and 
fourth graders had had at least one hour 
on the new machines. One of the rented 
LSI-11's was then returned (though few 
noticed its departure). At that time, sev- 
eral fourth graders were writing elaborate 
programs which made use of recursion 
to create "movies" or "rainbows" 
(changing colors), or elaborate scenes. 
Some students were so taken with 
LOGO that their parents happily bought 
them their own computers (at that time, 
ТІ LOGO was not yet commercially 
available); other students became so en- 
thralled with their ability to produce 
perfectly printed letters and numerals 
on a keyboard, and later received type- 
Writers as presents from their parents, 

By September 1980, a total of 50 TI 
LOGO prototypes were in operation at 
Lamplighter. The version of LOGO on 
these units was very close to that which 
TI will market. Then, late in the fall, the 
second LSI-11 was returned, but its loss 
went completely unnoticed because all 
of the faculty and student interest was 
already focused upon the ТІ LOGO pro- 
totypes. Since September, the Com- 
puter Group has continued to work in- 
dividually with third grade students. In 
addition, the other faculty are being 
trained in LOGO, and it has been intro- 
duced into all of the classes as part of 
the regular school curriculum. 

The teams at each grade level decided 
the best way to introduce LOGO into 
their classes, and worked out various 
procedures for that introduction. For 
example, one teacher developed special 
simplified LOGO programs for the pre- 
school children which required less typ- 
ing in order to produce interesting ef- 
fects. And personifications of LOGO 
constructs made LOGO easier for first 
and second graders to understand. Cur- 
rently, students can be seen at every 


shared-space LOGO machine during 
lunch-hour, before school, after school, 
and whenever other school activities are 
completed. For the rest of the semester, 
LOGO will be used in class by the 
teachers as they feel it is relevant for 
their lessons, and will continue to be 
available (as are the other learning aids) 
to students during free periods. 

The Lamplighter LOGO project was 
not intended to be a formal experiment. 
Since there are no control groups, strong 
causal claims for LOGO’s effects are in- 
appropriate. Several cognitive and psy- 
chological assessments, however, were 
made at the beginning of the project, 
and will be made again at the conclusion 
of the present school year. Nevertheless, 
there already have been some indications 
of student attitude and behavior change. 
This is best exemplified by the way in 
which the pupils express their keen re- 
gard and interest in acquiring new 
LOGO knowledge. 

It's always interesting to observe what 
motivates children to learn. Because 
there are so many things which TI 
LOGO can do, it is not possible for the 
Lamplighter teachers to show students 
most commands during the initial ses- 
sions. The students have taken this as a 
challenge and approach the discovery of. 
more LOGO commands as a treasure 
hunt. Whenever "unauthorized" LOGO 
information is found, it is disseminated 
through an "underground network" 
among the students. The teachers first 
became aware of this network late last 
year. When a few of the teachers were 
being instructed in how to use Make- 
shape (the LOGO mode by which users 
may make their own shapes in a 16x16 
grid) they were apparently being secret- 
ly watched by one or more students. 
Shortly afterward, а  hand-copied 
“underground” LOGO manual was 
found on the floor of a classroom; the 
purloined note concisely and accurately 
gave directions for use of Makeshape. 
And at about the same time, a number 
of students actually began using Make- 
shape. 


Other information has been un- 
covered by students accidentally. One 
student was trying to type MS for Make- 
shape but typed MC by mistake. This 
put him into Makecharacter mode (the 
mode in which LOGO users can modify 
existing characters or make their own). 
That student proudly shouted his dis- 
covery to his classmates, who quickly 
confirmed his results and spread the 
news to still more students. Students in 
the lower grades also pick up some ad- 


ditional LOGO knowledge from their - 


classmates with older brothers and sis- 
ters in the fourth grade. And occasion- 
ally, third graders see some of the fourth 
graders’ inventions when they walk 
through fourth grade shared-space, and 
they in turn attempt (often successfully) 
to duplicate those effects. Turtle geome- 
try, “movies” and “flash the screen” 
reached the third grade that way. Varia- 
tions of the "explosion" program (in ex- 
plosion, as the students call it, 32 col- 
ored shapes move from the center of the 
screen to splay out into a circle and 
then move back to the center in a tail 
recursive program), appeared one day in 
the third grade. These variants were 
traced back to a student whose father 
worked in the TI LOGO office. 


NEW, 


This pattern of sharing LOGO among 
peers is the overwhelming response of 
Lamplighter students. Pupils eagerly and 
proundly explain how they accom- 
plished something in LOGO to other pu- 
pils and even to teachers. However, 
there were—especially at first—a few ex- 
ceptions. A couple of students were se- 
cretive about what they knew in LOGO 
and how they achieved some LOGO 
effects. One such student went so far as 
to make the screen's background color 
black so that no one could read the in- 
structions he typed! Another student 
began collecting interesting LOGO pro- 
grams which he tried to se// to his class- 
mates! It would, however, be a distor- 
tion to present these two students as in 
any way typical of the Lamplighter 
pupils. The student who had hidden his 
typing on a black background soon dis- 
covered that others often found different 
ways to write programs that produced 
similar effects, and were willing to share. 
As a result of this discovery he is now 
also sharing Ais programs. 
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Іп at least one case, LOGO seems to 
be responsible for a major behavioral 
change. Late last year, a fourth grader 
who had not been performing well aca- 
demically, and who had been somewhat 
disruptive in class, started programming 


(QWERTY keyboards are quite properly 
regarded by the Lamplighter children as 
a stupid arrangement with which they 
reluctantly work), and his programs be- 
came sophisticated. He was heard to re- 
mark, “І can’t believe how fast my fin- 


Not only did he do well with LOGO, 
but he also became an attentive, produc- 
tive student. 

At present, most of the third and 
fourth graders—and even some of the 
first and second graders—are writing 


in LOGO. As he played on the com- 
puter, his typing became very fast 


gers are typing.” He also could not be- LOGO programs. And this includes 
lieve how much fun school had become. some fairly sophisticated programs 


which use recursion and the concepts of 
state transparency. It’s obvious that 
LOGO has indeed furthered Lamp- 
lighter’s goal of igniting the imagina- 
tions and intellects of its children, But 
more importantly, LOGO has the poten- 
tial to fire up imaginations everywhere. 


Hank Gorman will conduct a July.18th work- 
shop on LOGO. Interested parties contact 
him at Austin College. 


Check Our 
Dealer 


Directory 
(Page 64) 


The two finest programs 
for the TI 99/4* 


Santa Paravia 


and Fiumaccio 


The year is A.D. 1400, and you are the 
tuler of a tiny Italian city-state. You are 
ambitious by nature and intend to build 
your little city-state into a powerful king- 
dom. 

So begins Santa Paravia and Fiumac- 
cio, where you and your fellow players 
compete as rulers of neighboring cities. 
You control the grain harvest, feed your 
people, set tax rates, exercise justice, and 
invest in public works. 

Life was short back then, and you'll 
have only a limited amount of time in 
which to build your kingdom. The lives of 
your serfs will depend on your decisions. 
If they are wise, then your city-state will 
grow and you will acquire loftier titles. If 
your rule is incompetent, your people will 
starve and your city-state may be invaded 
by your neighbors. 

How will you rule your kingdom? Will 
you become unscrupulous and follow the 
example set by Niccolo Machiavelli in his 
book on government, The Prince—or will 
you be a benevolent ruler—an iron fist in 
a velvet glove? Only you can answer that 
question—with the Santa Paravia and 
Fiumaccio program. For TI99/4 Micro- 
computers. 

No. 027311 $9.95. 


Airmail Pilot 

Let the Airmail Pilot package take you 
to the early days of aviation history. Your 
plane is the Curtis JN4-D, affectionately 
known as the Jenny. You must fly the 
mail from Columbus to Chicago. 

The Jenny carries only 26 gallons of 
fuel. You'll have to stop along the way. 
Bad weather may force you down. Elec- 
trical storms may turn your aircraft into a 
mass of flaming wreckage, or ice may 
form on your wings and plunge you to 
certain death below. But, the mail must 
get through. і 

Experience the thrills of flying, when 
aircraft were mere fragile machines of 
wood and fabric, with the Airmail Pilot 
package. (Scarf and flying heimet option- 
al.) All you need is your TI99/4 micro 
computer. 

No. 0274TI $9.95. 


TO ORDER: 
See your local Instant 
Software dealer or call 
Toll-Free 
1-800-258-5473 


ХА trademark of Texas Instruments 


Instant Software: ^x: o 
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TI-99/4 SOFTWARE 
& Graphics Worksheets 


AVAILABLE PROGRAMS 


Complex derivative function 
Quadratic function 
Hyperbolic functions 

2x2 Matrix determination 
3x3 Matrix determination 
Hydrocarbon combustion 
Vector cross product 
Vector dot product 

Sigma function 


New: Computer Graphics Worksheet contains 
ASCII codes, color codes and 8x8 square 
grids for graphics planning. 


Pack of 25 worksheets.......... 5 
Each Ргодтат................ $2.00 
Minimum order $10.00 


Special Offer: All Programs and 
ay Pack of Worksheets only $15.00 


DATA SYSTEM 


2214 W. IOWA 
CHICAGO, IL 60622 


The Professional Answer 


Applications 
to streamline your administrative work 


Aene 


l'or district needs 


n's School Management Series (K-6) and Mathem 
{пе professional soft- ware Series (K-8). 
«school Management 
топ give you: 
reprogrammed modules tailored to 
our administrative needs 
е convenient information storage and 
вазу Access: 
е clearly organized printed reports 
з program instructions in plain English; 
helpful Reference Manuals 


ina 
ment Applications) and E0103:S3 
(Reading Skills Courseware Зепез:а 


ad» 9UnNTITY 
нора TUER 

море 

Gate оғ eURCHAsE к ЖОК 
созт 15) DI del 2 


“Фё сой, Foresman and Company 


Electronic Publishing 
Glenview, Illinois 60025 


99’er Magazine May/June 1981 63 


DEALER DIRECTORY 


Goleta, CA 


See our complete tine of personal 
and business computers including: 
Texas Instruments, Atari, Apple, 
Altos, Data General. Also All ac- 
cessories, software and supplies, 
Plus all that's new іп personal 
electronics, Personal Electro- 
nics, 5674 Calle Real Center, 
Goleta, CA 93117, (805) 
967-5322. 


Los Angeles, CA 


A soft ware/systems house primari- 
ly engaged in the sale of software 
for Ті and Polymorphic com- 
puters, Hardware sales are usually 
included in a combined turnkey 
package, Prospective customers are 
seen by prior telephone appoint- 
ment only. АААА Discount 
Computer How's, 13022 Pso- 
mas Way, Los Angeles, CA 
90066, (213) 391-8777. 


Greeley, CO 


K&K Electronics for everything 
you, need! HBO recelve dishes, 
Satellite earth stations, plus a full 
line of Texas Instruments Home 
Computer Hardware and Software. 
K&K Electronics, 615 8th 
Avenue, Greeley, CO 80631, 
(303) 352-3237. 


Waterloo, ІА 


Texas Instruments Large selectlon 
of Accessories and Software for 
99/4 at Dhein's True Value, 7 W. 
Airline Hwy, Waterloo, ІА 50701. 


Evansville, IN 


Independent Register 2414 N. 
Governor (across from Town Cen- 
ter Mall) is the tri-state location 
for ТІ-99/4 Hardware/Software, 
Supplies etc. We supply the tri- 
state with popular magazines and 
software for other units. Open 
Mon - Sat. 8-5. Independent 
Register, 2414 N. Governor, 
Evansville, IN 47711. (812) 
424-8246. 


Lexington, KY 


A complete line Texas Instruments 
dealer. We stock all Texas Instru- 
ments calculators and accessories, 
learning aids, home computer pro- 
ducts, accessories, perlpherals and 
software. Atari computers and 
Hewlett Packard calculators in 
stock. CBM Incorporated, 198 
Moore Drive, Lexington, KY 
40503, (606) 276-1519. 


Minneapolis, MN 
Authorized Texas instruments 
Т1-99/4 computer dealer offering 
you the best prices in the U.S.A. 
on the computer and all регірпег- 
als. Also, a wide variety of printers. 
CRT's available at lowest prices, 
No collect calls, please. Calcu- 
lators, Inc., 7409 Fremont 
Avenue South, Minneapolis, 
MN 55423, (612) 866-8908. 


Dayton, OH 


The only full line TI distributor 
stocking Semiconductors, DSG 
(700-800 OMNI Products) TM990 
Microcomputer Boards, Calcula- 
tors, complete in depth Inventory 
including 99/4 Products-Software. 
Ohio 1-800-762-9510. Surround- 
ingarea 1-800-543-9550. WIII ship. 
callus. Esco Inc., P. О. Box 
1166, 221 Crane St. Dayton, 
OH 45403, (513) 226-1133 


Medford, OR 


We have the ТІ-99/4 computer, 
Atari computers, video games, 
ptus a large selection of cartridges, 
software books and computer 
magazines. We offer membership 
in “The Source." You can have 
the world at your fingertips, The 
Computer Chip, 2640 "B" 
Barnett Road, Medford, OR 
97501, (503) 776-4091. 


Salem, OR 


J. Harvey's Video Clubhouse 
VCR's, Tapes, Home Computers 
т1-99/4, Atari 400, 800. 
J. Harvey's Video Clubhouse 
3295 Triangle Drive #142, 
Salem, OR 97302, (503) 
581-1003. 


Call a Dealer Today 


Dealers: 


New York, NY 


“Your Personal Guide to Personal 
Technology." We carry the com- 
plete TI-99/4 System. For demon- 
stration of the T1-99/4 at home, 
school or office, or more Informa- 
tlon call Next Tech, inc. today. 
Next Tech, Inc., 350 Fifth 
Avenue, New York, NY 10001, 
(212) 792-8768. 


Rye, NY 


Wide assortment of ТІ software, 
hardware and accessories all at 
discount prices, Also authorized 
Scott, Foresman dealer. Write or 
phone for nine-page catalog with 
hundreds of items. Microcom- 
puters Corporation, P.O.Box 
191, Rye, NY 10580, (914) 
967-8370. 


Electric City, WA 


Texas Instruments 99/4 Home 
Computer Systems — Wholesale 
prices and not on just the main 
console! Also good prices on 
Epson printers and  Televideo 
Terminals. For price list, write to: 
Komputar Works, P. O. Box 
483, Electric City, WA 99123, 
(509) 633-2653. 


Green Bay, МІ 


We specialize in the Texas Instru- 
ments 99/4 computer. We handle 
a complete accessory line for it, at 
discount prices, Custom program- 
ming for the 99/4 also done. Write 
for a complete price list. The 
Micro House, 527 Simonet 


Listings are $25 per issue; minimum Insertion, 3 issues (6 months). 
Prepayment of $75 required, Ads Include 35 words describing products 
and services, plus company name, address and phone, (No merchandise 
prices, please.) Call Pat at 503-485-8796 or write 99'er Magazine, Ad 
Department, 2715 Terrace View Drive, Eugene, OR 97405. 


Sale prices at store аге also given 
on mail orders, Write for price list. 
Dhein's True Value, 7 W. Air- 
lne Highway, Waterloo, IA 
50701,(319) 232-6225. 


Street, Green Вау, WI 54301, 
(414) 432-2871. 


Call a Dealer Today 


ATTENTION TI DEALERS 
Did You Know That You Can Be Reimbursed 
For Advertising Texas Instruments Products 


In This Magazine? 


99’er Magazine / Ad. Dept. 
2715 Terrace View Drive 
Eugene, Oregon 97405 
(503) 485.8796 


Call or Write 
Our Ad Department Today! 
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By Norma & John Clulow 


computer that hath no music in 

its chips nor is not programm’d 
with concord of sweet sound is fit but 
for business, mathematics, and sorts.” 
The ТІ-99/4 is definitely not one of 
these. 


Outstanding music and sound effects 
capabilities are among the many features 
which set the T1-99/4 apart from other 
personal computers. A user can generate 
three simultaneous tones and a noise, 
plus specify their duration, pitch, and 
loudness—all with a single ТІ BASIC 
statement. The sound is played through 
the speaker of the color monitor or TV 
display. 

Of course, an assortment of beep's, 
"tadaa's," and outer space sounds can 
greatly enhance a graphics presentation 
and provide useful auditory feedback 
during program execution. But when 
the sophisticated sound capabilities of 
the TI-99/4 become the focus of the 
programmer's attention, the Texas 
Instruments machine becomes a musical 
instrument in its own right. Whether a 
Bach Invention or a contemporary com- 
position of your own creation, a success- 
ful TI-99/4 performance is worth the 
programming effort. 

With the introduction of ТР5 Music 
Maker Command Module, you can take 
full advantage of the T1-99/4's sound 
capabilities without having to write a 
complex BASIC program. The Music 
Maker allows you to write a composi- 
tion using either of two methods—Tradi- 
tional Mode or Sound Graphs. While 
Traditional Mode requires some knowl- 


T о paraphrase Shakespeare, “Тһе 


edge of fundamental music theory, 
Sound Graphs does not. Both methods 
are graphics based, in contrast to other 
music editor formats which require en- 
try of notes using ASCII characters. Both 
also make superb use of the ТІ-99/4% 
outstanding color graphics capabilities. 
Notes are entered by manipulating the 
cursor with either the joysticks or the 
arrow keys. A composer can then print 
out the bass and treble clefs of each 
measure—complete with all notes, 
sharps, flats, andrests—with T's thermal 
printer (using its special graphic charac- 
ter set). It’s also possible to save the 
completed musical score on cassette 
tape or diskette. 


Traditional Mode 


In Traditional Mode, notes are en- 
tered directly on the music staff using 
standard notation. The first step involves 
defining the key, meter, and tempo. All 
possible key signatures (0-7 sharps or 
flats) are allowed. The meter or time sig- 
nature options for the denominator are 
1, 2, 4, 8, and 16—corresponding to the 
unit of measure receiving one beat (i.e., 
whole, half, quarter, eighth, or sixteenth 
note). The numerator of the time signa- 
ture indicates the number of such units 
which comprise a measure. Your options 
here are restricted to values equal to or 
less than the denominator. Examples of 
allowable time signatures are: 


4,6,2,and3; 
4382314 


but 3, 12, and 5 are not, since the 
2 8 


numerator exceeds the denominator. 


The significance of this limitation is tied 


to the fact that when music is accurate- 
ly interpreted by a performer, there is a 
natural accent which falls on the first 
beat of every measure. This regular im- 
pulse, together with phrasing and secon- 
dary accents in compound meters, gives 
a composition its underlying rhythmic 
structure. The Music Maker does not 
automatically provide for this natural 
rhythm. The implementation of accent 
is entirely up to you. For example, a 


composition written in 4 time may be 
made to sound like 2 time with proper 


phrasing and specification of accent. 
Therefore, the time signature limitation 
does not actually limit the music you 
can write with the module. Finally, 
tempo is specified as a number from 1 
to 30, corresponding approximately to 
metronomic indications from 25 to 128 
quarter notes per minute—a sufficient 
range for nearly all compositions. 

After these parameters are defined, 
the graphics representation for the first 
measure appears. Some music editors 
for other machines do not use graphics 
at all. It is a great advantage to see your 
composition displayed in standard nota- 
tion as you are writing it. 

Up to three voices may be "drawn" 
using whole, half, quarter, eighth, and 
sixteenth notes and their corresponding 
rests. Single dotting can be used with 
notes but not with rests. The notes for 
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each voice are represented іп а different 
color, which facilitates identification of 
voices when editing. 

The pitch range is three octaves, ex- 
tending from the second A below middle 
C {bottom space of bass clef) to the 
second A above middle C (first ledger 
line above treble clef). This may scem 
like a wide range. But in arranging 
several piano pieces for the TI-99/4, we 
found that it was frequently necessary 
to make octave transpositions for notes 
extending beyond the Music Maker’s 
pitch range in Traditional Mode. On the 
other hand, the Music Maker is really 
not intended for the transcription of 
existing music written for other instru- 
ments, but rather to facilitate original 
composition. And like all instruments, 
it does have limitations which must be 
taken into account when preparing an 
original composition. 

Accidentals (sharps, flats, or naturals 
not planned for in the key signature) 
must be written for each note; once 
written they do not carry over through 
the entire measure as they do in stan- 
dard notation. For someone who is 
accustomed to standard notation, this 
may take a little getting used to. Addi- 
tionally, the large and legible graphic 
symbols that the cursor picks up from 
the menu, become too small to be easily 
read when placed beside a note. 

Graphics characters for the notes 
themselves resemble square notation, 
but we do not feel this detracts from 
their readability (especially when com- 
pared with the legibility of many manu- 
scripts). However, in drawing clusters of 
two or more notes, we encountered a 
peculiar graphics-related difficulty. This 
is a function of the position (up or 
down) of an existing note stem. You 
will find that a note for one voice can 
not be placed at a pitch immediately 
above or below an existing note if that 
pitch is occupied by the stem of the ex- 
isting note. The stems for voices one 
and two go upward unless they are 
placed immediately below a note in 
another voice which has its stem going 
upward. The opposite is true of voice- 
three notes. This means that while it is 
possible to represent any two-note clus- 
ter, the process can be more involved 
than would seem necessary. For instance, 
suppose you have already written a 
voice-one quarter note at middle C, 
and you want to write a voice-two note 
at D immediately above it. Finding that 
you cannot do this simply. You would 
have to do the following: Change voices, 
erase the C, change voices, draw the D 
(voice-two), change voices, redraw the C 
(stem downward), and finally change 
back to voice-two to continue. A cluster 
of three notes with adjacent pitches can 
not be written at all. These problems 
will be troublesome only in the event 
that the composer wants to write disso- 
nant chords in the form of clusters. 
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At the bottom of the display there is 
a double row of squares; the upper row 
is used to specify volume for each note. 
There are eight levels of volume which 
allow a very smooth crescendo or dimin- 
uendo without abrupt transitions from 
one level to the next. By way of con- 
trast, some other music editors do not 
allow this degree of versatility in dyna- 
mics. The default value for loudness is 
the maximum level of eight. If you want 
to accent selected notes, say the first 
note of every measure, you must drop 
the volume of all other notes. A default 
loudness of six or seven might have been 
a little easier to use in this regard. 

The bottom row of squares is used to 
indicate the width of each note; this is 
very helpful in positioning them. It also 
allows one to create rests without using 
rest graphics by simply leaving a gap be- 
tween one note and the next. Two adja- 
cent notes of the same pitch are auto- 
matically tied. The only way to articu- 
late them is to leave a gap in between. 
For instance, one might write a dotted 
quarter rather than a half note or a 
dotted eighth rather than a quarter note, 
and the resulting gap would then pre- 
vent a tie with the next note. 

At any point during the writing of a 
measure, you can play an individual voice 
or al! voices. And if you decide to make 
а change, this is easily accomplished by 
erasing an individual note or the entire 
voice. However, you cannot insert or 
delete notes without making necessary 
adjustments to other notes in the 
measure. 

Repetition is easily handled by copy- 
ing an individual voice or all voices from 
a previous measure, and this can save a 
great deal of time. A given voice cannot 
be copied as another voice, however. So 
if you want to use the copy feature to 
write rounds, they have to be scored dif- 
ferently than they would be in tradi- 
tional composition, Any two voices can 
be copied by copying all three, and then 
erasing the one which is not wanted. 

When you are finished with a meas- 
ure, you can either go on to the next 
measure or back to a menu which allows 
you to edit, play, save, or print your 
composition. If you choose to edit, you 
will be shown the number of measures 
completed and the percentage of file 
space used, and you will be given the 
option of changing the tempo. To play 
the composition, you specify which 
voices are to be played, and you are 
given the option of hearing the music 
transposed up or down by as many as 
eleven half steps (twelve half steps are 
an octave). However, if you transpose a 
note so that it falls be/ow the Music 
Maker's range, it will not be played. 
You can interrupt the playing of a com- 
position and view the graphic represen- 
tation of the measure being played at 
that point, but graphics are not used 
when the piece is actually being played. 


There are a few features present in 
some music editors for other machines 
which are not present in Music Maker. 
For example, the only way to initiate 
repeats is by manually pressing "SHIFT 
R” during the playing of a piece;no form 
of looping can be structured into a com- 
position. However, given the relatively 
vast storage space available (compared 
with music compositions written in TI 
BASIC), together with the copying fea- 
ture, the lack of repeat capability is less 
significant than it might otherwise be. 
With 16K of RAM, you will be able to 
write about 900 notes for each of the 
three voices. For example, writing all 
sixteenth notes for three voices, the file 
could be 57 measures long; with all 
quarter notes, it could be 224 measures. 
Additionally, there is no capability to 
write phrases and then arrange them in 
different voices. This capability could 
be useful when employing the device of 
imitation, such as in writing canons and 
fugues. Even so, the same effect can be 
achieved with Music Maker-—it just takes 
a little more effort. 

Іп summary, despite the few short- 
comings mentioned, the Traditional 
Mode provides a beautiful graphics-based 
editor which makes the process of writ- 
ing music as enjoyable as listening to the 
finished product. Even if this were the 
extent of the Music Maker's capabilities, 
we feel it would be an excellent invest- 
ment at the suggested retail price of 
$39.95. 


Sound Graphs 


While some knowledge of music the- 
ory is essential for effective use of the 
Traditional Mode, the Sound Graphs 
method may be used without any prior 
understanding of music terminology. As 
the name implies, music is entered in a 
Cartesian coordinate graph format. The 
frequency graph can have a resolution 
of one hundred twenty vertical positions 
(frequency) by twenty horizontal posi- 
tions (duration) per “measure.” A Sound 
Graphs music file may contain up to 46 
measures. A color-coded line is plotted 
on the graph with the cursor, and as in 
Traditional Mode, a different color is 
used for each voice. 

The volume graph has a resolution of 
eight vertical positions (volume) by 
twenty horizontal positions (duration), 
and appears below the frequency graph. 
A separate volume graph may be plotted 
for each voice appearing in the frequen- 
cy graph (default is the highest volume). 
In addition to the three voices, a Sound 
Graph may also include a noise which is 
plotted on the volume graph. 

The user has the option of Discrete 
or “Continuous” tones. Under the 
Discrete option, the vertical axis is di- 
vided into thirty frequencies, consisting 
of C Major diatonic pitches from the 


second A below middle С to the third В 
above middle C. However, you can 
change any or all of these pitches with 
the List Tones option. Although any 
frequency from 110 Hz to 20,000 Hz 
can be used, tables are provided in TI's 
excellent documentation, giving the fre- 
quencies for chromatic, pentatonic, and 
gypsy scales. The frequencies can be 
changed at any time, even during or af- 
ter the plotting of a Sound Graph. 
Under the Continuous option you 
specify the upper and lower limits of 
the frequency range. These can be 
changed as often as you wish. The fre- 
quency axis is divided into 120 steps 
within this range, giving a frequency 
"slide" which sounds continuous and 
can be used to create sound effects such 
as whistles and sirens as well as interes- 


ting experimental music sounds. When 
you take into consideration the fact 
that a noise can be used in addition to 
three voices and that the composition 
can be played as fast as twenty charac- 
ters per second, the range of possibilities 
is quite extensive. 

In evaluating the noise, we were sur- 
prised to find that we could not distin- 
guish any difference between the peri- 
odic and “white noise" groups—i.e., 
noises 1-4 and 5-8, respectively. Noise 1 
appears to be the same as noise 5; noise 
2 the same as 6, etc. If you are familiar 
with the difference between periodic 
noise and white noise in ТІ BASIC, do 
not expect to find the same distinction 
using the Music Maker. 

Other aspects of using Sound Graphs 
are identical with the corresponding 


procedures used in Traditional Mode 
m editing, playing, saving, and print- 
ing). 

If you have no knowledge of music 
theory, using Sound Graphs is a great 
way to begin exploring the ТІ-99/4% 
music capabilities. If you are familiar 
with music fundamentals, you will be 
amazed at the versatility of the Sound 
Graphs method, and you will find that 
your ТІ-99/4 has potential you would 
not have thought possible. 

In conclusion, the Music Maker Com- 
mand Module will greatly enhance one 
of the already outstanding features of 
your computer—its capacity for sound 
and music. We believe it is an accessory 
you will not want to be without, 


a O  ——— a Á 


A Music Text Editor 
& File Player 
for the TI-99/4 


For those readers who do not as yet 
have a Music Maker, but would like to 
experiment with music writing anyway, 
a primitive music text editor follows 
this article, plus a file player program 
with the input required to play Bach's 
“Invention in F.” 

The Music Text Editor program cre- 
ates a tape file which is read and played 
by the Music File Player that follows it. 
Although the file can be played by the 
editor, the tempo will be somewhat 
slower than when performed by the 
separate player program. 


By Norma & John Clulow 


Use the following symbols to write note values : 


W - Whole 
Q - Quarter 
S - Sixteenth 


H - Half 
E - Eighth 


For a dotted note value, use one of these symbols followed by a“. ”; 
eg, "S .", "О. etc. 


Use the following symbols for pitches : 


А A# E 


B Е F# 


С Ся 
D D# 


С сё 
R (rest) 


After each pitch, give the octave (1-4) : 


Octave 


Begins 


Bottom space, bass clef 

Top line, bass clef 

2nd. space from bottom, treble clef 
1st. ledger line above treble clef 


For example, to play an F# in octave 2 and a C in octave 1 for a dotted eighth 
followed by a sixteenth rest, you would enter : Е. /F#/Ct/ followed by S/R/R/ 


The following commands may be used : 


CHANGE, REDO, LIST, PLAY, and SAVE 
The save command merges new data with data already stored in the tape file. 
You can SAVE a file in as many sections as you wish, but when you answer the 
question, "FINISHED?" with a “yes”, ап end-of-file mark will be written on 
the tape file. The Music File Player can read and play a file consisting of 550 


lines maximum. 
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REM 232558**1722*2233:12*253f*3 
REM t з 
REM Ж MUSIC TEXT EDITOR # 
REM t H 
REM *Xt*55*2129*T7T71321*$:2313 
REM 

REM BY NORMA % JOHN CLULOW 
REM 99'ER VERSION 5.81.1 
CALL CLEAR 

DIM Ме(11,4), $(8, 1), Р (549, 2) 
INPUT “TITLE - * 
INPUT "COMPOSER - 


FOR 120 TO 11 

READ N$(I,0) 

NEXT I 

рата A,09,B, C, Ct, D, D, E,F,F*, G, G8 
FOR Ізі TO 4 

FOR 2-0 TO 11 
Х=11042^ (3/12) 
GOSUB 1420 

№$ (1, I) =STRB(X) 
5=5+1 

NEXT J 

NEXT І 

CALL CLEAR 

PRINT “ENTER TEMPO 
INPUT “М.М. ж 
IF T4127 THEN 410 

PRINT :"MAXIMUM IS 126":3 

CALL SOUND(150,220,1) 

GOTO 360 

CALL CLEAR 

Т=6Е+4/Т 

FOR 120 TO 8 

FOR 250 TO 1 

READ V$(I,J) 

NEXT J 

NEXT І 

DATA W,4,H,2.H.,5,0,1.1,0.,1. 5,£, .5,E. ,. 75,9,. 25,8. , 375 
FOR I=0 TO 8 

XzVAL (МФ (1, 12) 

Хетях 

GOSUB 1420 

МФС, 1) =6ТАФ СХ) 

МЕХТ І 

CALL CLEAR 

КР=0 

GOSUB 1330 


(M.M.2": "QUARTER NOTES/MINUTE":: 


990 
1000 CALL SOUND(150, 220, 1) 


FOR N=1 TO 4-LEN(STRS(K+KP+1) > 
Хвахты" " 

NEXT N 

INPUT STRS(K+KP+1) МХА" 
IF К=550 THEN 670 
Р(К,1)=111 

РІК, 2) =111 

IF Х$<>"СНАМБЕ"ТНЕМ 700 
GOSUB 1570 

GOTO зво 

IF X#<>"PLAY"THEN 750 
GOSUB 1200 

GOTO зво 

IF X$<>"REDO"THEN 760 
GOSUB 1470 

GOTO зво 

IF X$<>"LIST"THEN 790 
GOSUB 1710 

GOTO 580 

IF X3<>"SAVE"THEN 810 
GOSUB 2160 

IF К<>550 THEN 840 
PRINT "SAVE FILE BEFORE PROCEEDING":: 
GOTO 580 

GOSUB 1270 

IF 5%=""ТНЕМ 870 

IF РМ<>0 THEN 890 

CALL SOUND(150, 220, 1) 

GOTO 580 

FOR I=0 TO В 

IF 5%=0% (1,0) THEN 950 

NEXT І 

PRINT "ERR- VALUE" 

CALL SOUND (150,220, 1) 

БОТО 580 

РК, 0) =VAL СУФ (1, 12) 

FOR 121 TO 2 

GOSUB 1370 

IF S$=""THEN 1000 

IF РМ<>О THEN 1020 


= "1х6 


Бото зво 

IF SS-"R"THEN 1150 

IF SEGS(SS,LEN(S$), 1) 4" "THEN 1060 
CALL 5оцмр (150, 220,1) 

6070 580 

OC=VAL (SEGS (S$, LEN (S$), 12) 
SS=SEGS (S$, 1, LEN(S$) -1) 

FOR Ј=0 TO 11 

IF 5%=№% (7,0) THEN 1140 

NEXT J 

PRINT "ERR- VOICE";I 

CALL SOUND(150, 220, 1) 

GOTO зво 

РІК, І) =VAL (NS (J, 0C) ) 

NEXT I 

IF 5820 THEN 1180 

RETURN 

Кекті 

GOTO 580 

FOR L=0 TO K-1 

IF РО, 1245111 THEN 1270 

IF P(L,2)€»111 THEN 1250 

CALL SOUND(P(L,O), 110,30, 110,30) 
GOTO 1510 : 

CALL SOUND(P(L,0) 110, 30,P (L,2) 1) 
GOTO 1310 

IF P(L,2)€»111 THEN 1500 

CALL SOUND(P(L,O),P(L,1),1,110, 30) 
GOTO 1510 

CALL SOUND(P (L,O) ,P(L, 12 ,1,P(L,2) , D 
NEXT L 

RETURN 

FOR 1=0 TD 349 
P(1,0)=0 

NEXT І 

RETURN 
PN=POS (ХФ, "/", PO) 

IF PN-O THEN 1410 
S$=SEG$ (X$, PO, PN-PO) 
PO=PN+1 

RETURN 

Ү=Х-ІМТ ОО 

IF Ү<.5 THEN 1450 
Каці 

X=INT OO 

RETURN 

Мек 

INPUT “START AT LINE - 
IF КЖР THEN 1520 
CALL SDUND(150, 220,1) 
GOTO 1480 

Kzk-KP-1 

IF K<M+1 THEN 1560 
CALL SOUND (150, 220; 1) 
BOTO 1480 

RETURN 

EI 
ме 
INPUT "CHANGE LINE - 
IF K>KP THEN 1630 
CALL SOUND (150, 220,1) 
GOTO 1590 

кекокеої 

IF К<М THEN 1670 
CALL SQUND(150,220,1) 


"К 


GOTO 1590 

GOSUR 580 

кам 

SR=0 

RETURN 

INPUT "FIRST LINE - “:0 


IF O^KP THEN 1750 
CALL SOUND(150,220,1) 


БОТО 1710 

INPUT "LAST LINE ~ ":Q 
IF Q>KP THEN 1790 

CALL SOUND(150,220,1) 


GOTO 1750 

IF 0<=0 THEN 1820 
CALL SOUND (150, 220, 1) 
SOTO 1710 

ТЕ 0-кР<К%1 THEN 1840 
Q=K+KP 


Q-G-KP-1 

FOR R-O TO 0 
x$=" 
FOR Іші TO 4-LEN(STRS(R+1)) 
X$-X$&" " 

NEXT I 
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Music Editor, сопііпией... 100 REM Заза ааа 


110 REM + з 
920 Р зи - “; 
i S Um Dco а а REN 5 120 REM 4 MUSIC FILE PLAYER з 
150 REM 4 з 
IF PER VAI 
1930 МЕХТ ae Oe tS pII аран 140 REM %:%1%%5%%%555%5351%5555353 
150 REM 
19 PR vs &"/"; 
1020 pial Isi 18:02 d 160 REM BY NORMA & JOHN CLULOW 
1980 IF P(R,I)<>111 THEN 2040 170 REM 99°ER VERSION 5.81.1 
ото ЛЕ Теза. THEN 2020 190 ERINE RES PROGRAM PLAYS А MUSIC FILE 
2000 PRINT "R/" 
2010 GOTO 2140 { CREATED BY THE 2-VOICE EDITOR." 
2920 лыны ы 200 PRINT :"X PLACE DATA IN CASSETTE CS1":" 
2040 FOR 11=0 TO 11 THEN: RESE. ENTER 
2050 FOR 12=1 TO 4 210 CALL SOUND(150, 1400, 1 
2060 IF P(R,1)<VAL(NS(I1,12)) THEN 2090 220 CALL KEY (0, KEY, STATUS) 
2070 IF P(R,1)=VAL(NS(I1,12)) THEN 2100 250 IF КЕУ<215 THEN 220 
2080 NEXT I2 240 DIM P(S49,2) 
2090 NEXT 11 250 OPEN 41:"CS1",SEQUENTIAL, INTERNAL, INPUT 
2100 IF 152 THEN 2130 FIXED 192 
2110 PRINT N$(I1,0) &STR$ (12) &"/"; 260 PRINT :"% READING" 
2120 NEXT I | 270 CALL SOUND(150,1400,1 
2130 PRINT N$(II,0)&STR$(IZO NR" /" | 280 INPUT 81:45, СФ 
2140 NEXT R | 290 FOR 1=0 TO 549 
2150 RETURN 300 FOR 2-0 TO 2 
2160 IF F$-"1"THEN 2200 310 INPUT 91:X$, 
2170 Р%="1" 320 IF X$2""THEN 510 
2180 OPEN &1:"CS1",SEQUENTIAL, INTERNAL,OUTPUT,FIXED 192|| 330 IF X$-"9299939"THEN 370 
2190 PRINT #1:1$;С$ 340 P(,J)SVAL (X$) 
2200 11-0 550 NEXT J 
2210 К-к-1 560 МЕХТ І 
2220 FOR I=1 TO 12 370 CALL CLEAR 
2230 FOR Ј=0 TO 2 ТВО PRINT TAB((28-LEN (N$)2 /2) jN$11 TAB (15); "BY" 


2240 PRINT #1:5ТА% (Р(І1,2)), 


2250 NEXT 2 ::ТАВ((28-1ЕМ(С9)2/29;С%:: 

2260 11=11+1 j 590 FOR К=0 TO 1-1 

2270 IF 11>K THEN 2330 400 IF P(K,1)<>111 THEN 440 

2280 NEXT І 410 IF P(K,2)«»111 THEN 470 

2290 PRINT #1:5Т8$ (Р (11.0) ) , STR$(PCI1, 1) , STRS(PCI1,2)^ 420 CALL 500Мр (Р (К, 0), 110, 50, 110, 50) 
2300 11=11+1 430 GOTO 500 

2310 IF 11 THEN 2340 440 IF P(K,2)<>111 THEN 490 

2320 GOTO 2220 450 CALL SOUND(P(K,0),P(K,1),1,110,30) 
2550 PRINT #1:"" 460 GOTO 500 

2340 PRINT "FINISHED? (Y/N)" 470 CALL SOUND (РІК, 0), 110, 50, Р(К,2), 1) 
2350 CALL KEY (0,KEY, STATUS) 480 GOTO 500 

2360 IF KEY=89 THEN 2410 490 CALL SOUND(P(K,0O) ,P(K,1), 1,P(K,2),1) 
2370 IF KEY<>78 THEN 2350 500 NEXT K 

2380 КРЕКР+К+1 $10 CALL CLEAR 

2590 K=0 520 PRINT "SELECT FROM...":::1"(1) PLAY IT AGAIN" 


2400 GOTO 570 | 
2410 PRINT 41:"3923233" 


1:" (2) NEXT PIECE"::"(3) STOP" 
550 CALL KEY(O,KEY,STATUS) 


2420 CLOSE #1 | $40 IF KEY<49 THEN 550 
2450 PRINT T$&" SAVED" $50 IF KEY>S1 THEN 550 


2440 END 560 KEY=KEY-48 


570 ON KEY GOTO 370,280,580 
580 CLOSE #1 


Entries for Invention in F 590 STOP 
Primitive Music Editor 3 
М.М. 
1“ S/F3/42/ 5? = S/D3/F2/ S/E3/C2 S/C3/F1 tht = S/C3/B2 
2 = S/R/MI2/ - S/F3/R MI 142 on АУД 
2 = 5/с3 wal = S/E4/G1 А 143 YY 
$ V, B SA V ш: 
5 = S/Cl/R - УК 116 = WAS 
ў = и 147 = Уу 
8 з C1 148 = S/R/Ft 
9n m 2 D 159 = S/C3/EL 
10 = 150 = S/R/Di 
іа : 151 = E/Ch/C1/ 
13 = 152 = S/Bh/E1 
14 = 8 = 153 = S/AN/R 
ie 99 = 15% = sue 
- = р 155 = S/Ah/R 
1? = 1/ te 100 = 2 156 = S/ü3/Ei 
I5 З/АЙЗ/ҢУ d 101 = 5/62/в2/ 157 = S/F3/R, 
18 ИА 02/7 kG = 102 = S/A3/C2/ 158 = S/k3/C2, 
14 = 5/АЁЗ/Ң/ pa в 103 = S/G2/B2 159 = Д 
ds S/A3, Ww 1552 104 = S/F2/A2/ 160 = S/E3/G1 
5502 5/62/в, id Е 105 = 5/82/61 161 = S/D3/R 
| 4522 E/P2/R/ 50 = і 106 = S/F2/R 162 = S/C5/DJ2 
2275.8 УЛ, 51 = 8/63/АЙ3/ 107 = S/E2/C2/ 163 = S/AJ3/R, 
гры S/R/D2 52 = S/AM/C3/ 108 = S/D2/B2/ 164 = S/c3/F#1/ 
| 22 = ӘСУСУ 53 = ЕЙҮЛЕЙ 109 = S/C2/A2, 165 = S/al/R/ 
m S/R/D2/ 5h є Б/АН/СУ/ 110 з S/R/B2 166 = 5/С3/042/ 
227 5/АЗ/С2/ 55 = 5/G3/A#3/ 111 = S/C3/A2/ 167 = S/Ah/R 
S/R/A#2/ 56 = з/ай/с3/ 112 = S/B3/C1/ 168 = S/A#3/F#1/ 
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Data for Invention іп Р, continued . 
169 = S/A4/R/ 214 = yon 259 з S/G3/R/ S/ A43, 349 = S/G2/R/ 
170 = S/C3/D#2/ 215 = S/R 260 = $/АЗ/С#1/ S/D3/F. аўд 350 = 5/ғ2/ғі/ 
171 = S/AK/R/ 216 = S/Mfh Ж 261 = $/G3/R/ S/C3/Dff2 
172 = 5/АЗ/Е#1/ 217 = S/R/E2 262 = S/B3/El 351 = S/D#2/R/ 
173 = З/АВ/В/ 218 = S/C#3/E1/ 263 = S/G3/R 352 = S/D2/A#2/ 
17h = 3/a#3/G1/ 219 = S/R/E2/ 26h = s/c#3/a1/ 353 = 5/8/02/ 
175 = S/R/G1/ 226 = Vy 265 = S/G3/R/ 5h = S/a2/Mf2 
176 = S/G2/F1/ 221 = S/R/E1 266 = 5/АЗ/С#1/ 355 = S/F2/A2 
17? з S/R/D41/ 222 = З/АЗ, 5d 26? = S/G3/R/ 356 = 5/Е2/01/ 
178 = S/A#3/D1 223 = S/R/D2 268 = S/F3/D1 357 = S/F2/A2/ 
179 = 5/к/рф1 224 = S/F3/Fi 269 = S/R/D1 58 = 5/Е2/б1 
180 = 5/62/01 225 = S/R/D2 270 = 5/03/С1 359 = 5/р1/Р1/ 
181 = R/C1 226 = S/D3/E1 271 = S/R/D1 360 = S/C2/F1/ 
182 = 5/БЗ/АНІ/ 227 = S/R/D2, 272 = S/A#3/G1/ 361 = S/D2/F1/ 
183 = S/R/C1/ 228 = EY A 273 = S/R/Di 362 = S/C2/E1/ 
184 = EA val 229 = S/R/D2, 27% = s/D3/A1 363 = S/A#2 Y 
185 = S/R/A1/ 230 з S/F3/Di 275 з Ха 36h = 5/А2/С1 
186 = E/G3/a1/ 231 = S/R/D2 276 = S/G2/A#1/ 365 = S/A#2/R/ 
187 = S/F3/61/ 232 = 5/63/А%2/ 7 = S/R/D1/ 366 = S/A2/T1/ 
188 = S/Df3/R/ 233 = S/F3/R/ 278 - S/F3, га 367 = S/G1/E1/ 
189 = 5/рЗ/А 2 234 = 5/63/01/ 79 = S/R/D1 б ии 
190 = 5/D#3/R, 235 = Б/АЙН/Е/ 280 = S/E3, y 
191 з S/D3, чи 236 = 5/СУ/ВІ/ 281 = 5/В/С1 
192 = S/C3/R 237 з S/A#4/R/ 282 = S/C3/Af1/ 
193 = AAS УАЙ 238 з S/D3/G1/ 283 = S/R/C1 
194 = $/03/R 239 = S/ABR/R/ 28% = S/A3/F1 
195 = S/AB3/G1/ 240 = S/E3/C1/ 285 = S/R/C1 
196 = S/A3/R/ 241 = З/АЙЬ/В/ 286 = 5/С3/б1 
197 = E/G2/K 242 = Б/СЭ/Е1/ 287 = S/R/C1 H 
198 = S/A#3 к 243 = S/ARY/R/ 288 = S/F2 ху 2/ 
199 = S/R/DH2 244 = З/РЗ А?/ 289 = s/r/cr УА 2/ 
200 = S/D3/D2, 245 - EUR 200 = Wa 7 h 
201 = S/R/D#2 246 = S/P3/Fl 1 = $/R/C1 3 2 Н 
202 = EAE 247 = S/Ah/R 292 = 5/D3/A#1/ oy 381 = S/R/MA/ 
203 = S/R/C2/ 248 = 85/83/01 293 = S/F3/R S/62/A2/ 382 - Mi, 
гой = З/СЗ/АНО/ 249 = SA 29h = 5/0#3, /D1/ Аф2/ 3 R/A#1 
205 з S/R/C2/ 250 = З/СИЗ/ВІ/ 295 = S/P3/R у 
206 = S/D3/AM2/ 251 = З/АЊ/В/ 296 = S/D3/FL 3) 
207 = S/R/A2 252 = S/D3/B1 297 = S/F3MR S/03/C1/ 
208 з S/a#h/G1/ 253 = 5/АШ/Ң 298 = S/D#3/D1/ R/ 
209 « S/R/F1/ 254 = S/83/D1/ 299 = S/F3/R/ F1/ 
210 = 3/0#3/G1/ 255 = з/Ай/В/ 300 = S/D3/A#2/ 3/A# 3/R/ 
211 = 27 256 = S/E3/G1/ 301 = S/F3/R М 
212 = S/A#4/G1/ 25? = S/D3/R/ 302 = S/D#3/F1/ ўра? 2/R 

| 213 = з/ң/Е2/ 258 = S/E Mu 303 = S/F3/R/ S/F2/A2/ 


Cassette Compatibility At Last! 


If The TI-99/4 Will Not 
Control Your Cassette 


Recorder Through 
Its Remote Jack, We Have The Solution For You... 


с” The TI-SETTE Adapter 


* Quickly connects between the black lead on the TI Dual Cassette 
Cable and your recorder's remote jack to establish compatible 
polarity. 


| * Low cost — Only $3.50 plus 75 cents postage & handling. 


Е 

гы =“ 

INNOVATIVE PRODUCTS 
- : FOR TMS9900-BASED 

| PERSONAL COMPUTING 


Р. О Box 5537, Eugene, Oregon 97405 
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Perfectly Balanced 
Ge, П 


99/4 


educational software 
from 
MICRO-ED 


Excellent instructional programs 


Unless otherwise specified, each one can be 
purchased for 49,95 on Disk only 


| - Send for free catalogue: 
MICRO-ED, Inc. * P.O. Box 24156 * Minneapolis, MN 55424 
| 2222 Ortelephone us at (612) 926-2292 
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Tiny Math 
for 
Tiny Tots 


By Pat Kaplan 


ne evening, about a year ago, | 
Ф out a book and curled 

up in front of the fireplace with 
it, expecting to soon become drowsy and 
have to go to bed. As it turned out, the 
book completely captured my imagina- 
tion and wouldn’t let me put it down 
until | had read it cover-to-cover, re-read 
selected parts, and had to hurry off, 
bleary-eyed to work the following morn- 
ing. What made the experience so un- 
usual was that the book didn’t make 
any bestseller lists, wasn’t made into a 
movie, and wasn’t a thriller, exposé or 
sweeping Gothic romance .. . 


The title of this book intrigued me 
the first timc І saw it sitting on a book- 
store shelf: Teach Your Baby Math—an 
improbable-sounding title, at best... 
The author, Glenn Doman, is the 
founder and director of The Institutes 
for the Achievement of Human Poten- 
tial. He and his staff have worked many 
years with brain-injured children, and 
have been extremely successful in bring- 
ing these children from neurological 
dysorganization to average or superior 
neurological organization. By the mid- 
1960s, they were directly responsible 
for hundreds of severely brain-injured 
children who could read and read well, 
with total understanding at two years 
of age. These children were taught by 
their parents at home. Doman's work 
then naturally progressed to ей chil- 
dren, and showed equally encouraging 
results. 

Mathematics was then the next logi- 
cal step. Doman and his staff already 
knew that you can teach a baby any- 
thing that can be presented in a factual 
way, and they knew that the younger 
a baby is, the easier it is to teach him or 
her. Their problem was simply to decide 
what were the actual facts of mathema- 
tics. Once you have taught a child the 
facts about anything, he will intuit the 
rules. 
72 


99'er Magazine May/June 1981 


Once you have 
taught a child 
the facts about 
anything, he 
will intuit 
the rules. 


It took ten years before they were 
able to solve the problem. The solution 
that emerged was a daily program for 
teaching small children number percep- 
tions, addition, subtraction, multiplica- 
tion and division through the use of 
numerical dot cards. A child learns to 
recognize the number of dots (from one 
to one hundred) on the cards, and to 
use these quantitative relationships to 
do mathematical operations. The meth- 
od goes beyond simply teaching a child 
to do math problems; it also has parents 
enhancing their baby's intelligence by 
actually increasing his brain growth. 

Г was hooked. This was something І 
just had to try with my two year old 
son. Well, to make a long story short—l 
have tried it, and it actually works! So, 
when my husband was starting this 
magazine, it seemed like a good idea for 
me to suggest, at one of the early staff 
meetings, that we implement the dot 
card method on the Т 1-99/4 and publish 
the program listing in the first issue. 
This we have done, and named Tiny 
Math 1. 


Actually there are three reasons why 
| felt we should adapt the method for 
use via computer-assisted instruction, 
and publish the software: First, the ac- 
tual production of the dot cards is both 
time-consuming and expensive (about 
$50 for materials); but it could instead 
be simulated quite well (by the comput- 
er) on a color TV or monitor. | want as 
many parents as possible to try the 
method with young children, without 
having to spend alot of money. (By the 
way, this program can Бе played crea- 
tively as a family "number guessing 
game" for toddler, older child and 
adult. Secondly, | wanted to take 
advantage of the computer's ability to 
truly randomize the dot placement 
(instead of casier-to-recognize fixed 
pattern clusters inherent in a card sys- 
tem), and be able to change the dots to 
other shapes, and the white background 
to other colors. Additionally, | wanted 
to have speech synthesis as an option. 
Although the introduction of all thesc 
“bells and whistles” might have de- 
tracted from the basic simplicity of the 
method, І now feel that the element of 
novelty and interaction that has resulted, 
more than compensates. By the way, 
the third reason why | wanted to sct up 
this unique learning method on the 
T1-99/4 and publish the details was, РІЇ 
admit, а little vain—I wanted to see my 


name in print... aq 


Note: 

To really understand this method, 
and put it into practice, you will also 
need the book, Teach Your Baby Math. 
As a convenience to our readers, we are 
stocking this title in the 99'er Bookstore. 
Sec the book pages in this issue for price 
and ordering information. 


Tiny Math 1 


By W. K. Balthrop 


It then gives a child a choice of five different shapes 

to use for the screen ‘‘dots.” The color of the shape 
will always be a dark red, but the background color of the 
screen can be changed. The parent or child then selects the 
range of dots to be displayed from two to one hundred. An 
example of this would be: Lowest possible number of shapes 
= 10. Highest possible number of shapes = 20. This would 
cause a number of shapes from 10 to 20 to appear randomly 
on the screen. The program then asks how long the shapes 
stay on the screen, from 1 to 7 seconds. If desired, this time 
range can be altered by changing the maximum time allowed 
in line 1000 of the program, or changing line 1610 for the 
time delay control number. 

Before the exercise starts, the program offers a choice 
of either going into a teaching mode, or directly into the 
quiz mode. The teaching mode will cycle 25 times. The 
shapes will be displayed in the same fashion as in the quiz 
mode, but will remain on the screen with the exact number 
of dots indicated at the top. They remain there until a key 
is pressed—giving a child adequate time to observe the dots. 

An important aspect of this program is that it will flash 
all of the shapes on the screen at the same time, this elimi- 
nates the problem of counting the shapes as they would ap- 
pear, one by опе. This is done by using CALL COLOR to 
make the shapes invisible. At the time the shapes are to 
appear, the CALL COLOR command is used to make them 
red. By the way, it's important that the child doesn't have 
the time to count. 

In coding the program, | was faced with the problem of 
keeping the shapes centralized on the screen without 
crowding them. There shouldn't be two shapes touching 
each other, for that might be confusing; they shouldn't be 
spread out all over the screen either. It was necessary to do 
a lot of checking for adjacent characters, and give pattern 
size limits, depending on the number of shapes. All of this 
slows things down a little, so don't be surprised if it takes 
some time to display the shapes when there are a lot of 
them used. 


T he program starts by asking whether speech is desired. 


Another feature is the re-testing of missed guesses. Ap- 
proximately every other display will be one that the user 
has already missed—providing that he or she has missed any. 
When that number has been guessed right, it will be elimi- 
nated from the wrong guess storage. "н 


4 
PROGRAM EXPLANATION 


Line Nos. 
100-170 
180-420 
430-490 
500-680 
690-770 


REM statements, 

Print title page, and play music. 

INPUT option to use speech. 

INPUT type of shape desired. 

INPUT number of shapes desired. 

780-930 INPUT the screen color desired. 

940-1010 INPUT time for shapes to be on the screen. 

1020-1070 INPUT choice to teach first, or learn mode. 

1080-1140 Teaching mode control loop. 

1150-1210 Learning mode control loop. 

1220-1320 END of program. Quit or continue, 

1330-1580 PUT invisible dots on the screen; check for 
dots next to each other. 

1590-1640 Blink dots on for a given time delay. 

1650-1750 INPUT user’s guess. Check for right or wrong 
answer. 

1760-1900 Answer was right. If answer was in the wrong 
answer storage, it will now be removed, 

1910-2100 Answer was wrong. Store missed number to 
be used later. 

2110-2260 Turn dots on until enter is pressed. Display 
number of dots at bottom of screen. 

2270-2880 Set up string variables to say the correct an- 
swer, when using speech. 

2890-3000 Set up variables for next test. 

3010-3040 END of test. Print score, and END. 


100 REM  ***£t**331:$*13*21 


110 REM з x 
120 REM £ TINY MATH 1 з 
130 REM з а 


140 КЕМ FKKHRRAR ARTA 


150 REM BY W.K. BALTHROP 
160 REM 99°ER VERSION 5.81.1 
170 REM INITIALIZATION 


180 RANDOMIZE 

190 CALL CLEAR 
200 CALL SCREEN (16) 
210 PRINT TAB(8) 


TINY MATH 1" 


C7EFFFFFFFF7ESC" 
ЕРЕСЗСЗСОЗСЗЕРРЕ" 

270 G8(4)="81467E3C3C7E6681" 

280 G$(5) E"FFFFFFFFFFFFFFFF " 

290 DATA S23, 494, 440, 494, 525, 525, 523 
291 рата 494,494,494, 523,523,523, 525 
292 DATA 494,440, 494,525, 523, 525, 525 
300 DATA 494,494,523, 494, 440, 44000 
310 FOR Х=1 TO 5 

320 CALL CHAR(95+X, бе ОО» 

330 NEXT X 

340 FOR ENT-1 TO 5 

350 RESTORE 


360 FOR ENR=1 TO 27 

370 READ 5 

380 IF ENR=27 THEN 410 

590 CALL SOUND(100,S,5) 

400 CALL VCHAR (ІМТ (RND$24) +1, INT CRNDES2) +1, 95+ENT) 
410 NEXT ENR 

420 NEXT ENT 

430 REM USER INPUTS 

440 CALL CLEAR 

450 CALL SCREEN(B) 


460 PRINT " DO YOU WANT TO USE SPEECH" 
470 PRINT " 1 FOR YES" 
480 INPUT ~ 2 FOR м0":5 


490 IF (5<1)+(5>2) THEN 440 

500 CALL CLEAR 

510 PRINT "WHAT SHAPE DO YOU WANT TO USE" 
29 IF 5421 THEN 540 

520 CALL SAY (“WHAT+SHAPE+D0+ YOU+WANT+TO+USE") 
$40 PRINT "1 FOR ";СНАФ (92) 

550 PRINT 

560 PRINT "2 FOR "iCHR$(97) 

$70 PRINT 

580 PRINT "3 FOR ";CHR$(98) 

590 PRINT 

600 PRINT "4 FOR ";CHR$(99) 

610 PRINT 

820 PRINT "5 FOR ";CHR$(100) 

630 INPUT Саз 
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Тіпу 


1870 
1880 
1890 
1900 
1910 
1920 
1930 
1940 
1950 
1960 
1970 


2060 
2070 
2080 
2090 
2100 
2110 
2120 
2150 
2140 
2150 
2160 
2170 


о GOSUB 


Math 1, continued ... 


WER? 20 

NEXT ER 
RIGHT=RIGHT+1 
RETURN 
REM 
FRINT " 
PRINT 
IF 5521 THEN 1980 
BOSUR 2270 

CALL 
CALL 
CALL 
CALL 
CALL COLOR(9,2,1) 

FOR V=1 TG 100 

NEXT У 

WET) SNC 

KTSKT+! 

PRINT “WE WILL TRY AGAIN" 

IF 5621 THEN 2080 

CALL SAY ("WE+WILL+#TRY AGAINW 
FOR TD-1 TO 500 

NEXT TD 
RETURN 
REM 
CALL COLOR(9,7,1) 


WRONG ANSWER. 
HOH, 


SOUND (500, 440, 


TURN ON DOTS PERMANENTLY. 


THAT IS INCORRECT” 
THE RIGHT ANSWER IS";NC 


") 


PRINT ТАВ{10); "RENTER ANY KEYS" 


IF NC«10 THEN 2170 


SAY(C'UHOH #THAT IS INCORRECT# ") 

SAY(O' THE*RIGHT*ANSWER*IS","",NUM$,"", TES, '") 
2,550.2,165,2) 
SOUND (400,550,2,220,2,110,2) 


DISPLAY NUMBER OF DOTS. 


CALL VEHAR (2,5. ASC (STR (ІМТ (NC/10)))) 


GOTO 2180 
CALL VCHAR(2,5, 22) 


CALL VCHAR (2,6, ASC (STRS (NC- (ІМТ (МС/ 10) $10) ))› 


THEN 2240 


GOSUB 2270 


CALL SAY('THERE*ARE", "", ММФ, "", TES, "", "SHAPES+ON+THE+SCREEN”) 


CALL KÉY(O,K,STAT) 

IF STAT-O THEN 2240 
RETURN 

FC#INT(NC/10) 
SC#NC- CINT (NC/10) #10) 
IF FCsO THEN 2 
ON FC BOSUR 25 
BOTO 2550 

FCS 
IF SC-0 THEN 
2870 
GOTO 2370 
scte="" 

IF NC>20 THEN 2480 
IF NC>9 THEN 2410 
NUM$=SC% 
RETURN 

ТЕ SC>S THEN 


2360 


2450 


NUMS$=FCS 

IF SC»O THEN 2520 
Tes="" 
RETURN 
TES=SCS 
RETURN 

IF SC>0 THEN 
FCS="TEN" 
RETURN 

ON SC GOSUB 2590, 2610, 2630, 
2650, 2670, 2690, 2690, 

2690, 2690 

RETURN 

FC$-"ELEVEN" 

RETURN 

FCS="TWELVE” 

RETURN 

FCS="THIRTEEN* 

RETURN 

FC$-"FDURTEEN" 

RETURN 

FC$-"FIFTEEN" 

RETURN 

FC$-2"TEEN" 

RETURN 

FC$-"TWENTY" 

RETURN 

FC$-2"THIRTY" 


2570 


2740 
2750 
2760 
2770 
2789 
2790 
2800 
2810 
2820 
2950 
2840 
2850 
2860 
2870 
2880 
2890 


2900 
2910 
2920 
2930 
2940 
2950 
2960 
2970 
2980 
2990 
3000 
зоо 
3020 
3030 
5040 


+2710, 2720, 2750, 2770, 2790, 2810, 2830, 2850 


RETURN 
FC$-"FQURTY^ 

RETURN 

FC$-"FIFTY" 

RETURN 

FCs-"SIXTY" 

RETURN 

FC$="SEVENTY” 

RETURN 

FC$-"EIGHTY" 

RETURN 

ЕСз= "МІМЕТҮ" 

RETURN 

SCS=STR$ (5С) 

RETURN 

REM SET UP VARIABLES 
FOR NEXT TEST 

FOR x=! TO 50 


BOTO 440 

REM END OF TEST MESSAGE 
PRINT "YOUR SCORE WAS";RIGHT 
PRINT “ПОТ OF A POSSIBLE So" 
END 


Want to Get 
Published? 


99'er Magazine is looking for 
articles in all areas of personal 
computing that concern the 

Texas Instruments Т1-99/4 and 

other TMS9900-family systems 

(e.g., Marinchips, Technico, and 

the TM990/189). Here аге the 

kinds of articles that we want 
you to write for us: 

* Are you a businessman, pro- 
fessional, hobbyist, scientist, 
or engineer with an interest- 
ing microcomputer applica- 
tion? Tell us how it works, 
what problems you've had to 
overcome, and what recom- 
mendations you have for 
others. We're especially inter- 
ested in sharing user-written 
software with our readers. 

* Have you recently purchased 
a piece of hardware or soft- 
ware that hasn't quite come 
up to your expectations, or 
has, on the other hand, im- 
pressed you with its perform- 
ance? We're looking for 
comprehensive product and 
book reviews from different 
perspectives, 

* Are you an educator or par- 
ent with something to con- 
tribute to computer-assisted 
instruction (CAI)? We're al- 
ways looking for new ideas 
and fresh approaches to edu- 
cational problems. 

* Have you created any unusual 
computer games or simula- 
tions? Let our readers ex- 
perience your excitement 
and pleasure. 

* Perhaps you've modified your 
microcomputer or have inter- 
faced it with some unique or 
uscful hardware. Send us 
your how-to-do-it story. 
These are just some ideas. 

Perhaps you have others. Don't 

worry if you're not a profes- 

sional writer. Our editorial staff 
stands ready to help polish up 
your manuscripts. And we'll be 

more than happy to send you a 

copy of our author's guidelines. 
Send your manuscripts and 

correspondence to: 


99'er Magazine / Editorial Dept. 
2715 Terrace View Drive, 
Eugene, Oregon 97405 
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he game of chess has fascinated 
Т“ and women for hundreds of 

years. People from all walks of life 
and of all ages have enjoyed the chal- 
lenges and entertainment it provides. 
The universal popularity of chess is un- 
doubtedly due to its resemblance to life: 
Mastery of chess requires many of the 
same elements necessary to mastery of 
one's life—logical thought, long-range 
planning, the ability to recognize and 
act on sudden opportunities, persistence, 
patience, concentration, steady nerves, 
confidence, objectivity, and of course, 
lots of experience! Yes, to do well in 
chess does require all these things, but 
interestingly enough, practicing the game 
greatly helps develop and nourish these 
same characteristics and abilities! “Learn- 
ing to Play" is, in reality, one and the 
same as “playing to learn.” 

And yet, for all its challenges and self- 
improvement attributes, the game is 
enjoyable at all levels of skill—from the 
raw novice, to the international master. 
Over the years, chess has indeed pro- 
vided me with hundreds of hours of en- 
grossing entertainment and many cher- 
ished friendships. 

With the advent of strong chess-play- 
ing computer programs, chess has entered 
an important new stage of development. 
People can learn chess much more rapid- 
ly than before without the often deflat- 
ing experience of losing many games 
"in public." This is especially true for 
children; losing badly to adults or other 
children can often drive them from the 
game. Having a ready and discreet oppo- 
nent docs indeed have its advantages... 


About the Author 

Jerry Wolfe is a professor of mathematics 
at the University of Oregon in Eugene, Oregon. 
He has been playing chess since the age of 
eleven and began playing in chess tournaments 
at the age of fourteen. He is the 1979 Oregon 
Open champion and has won numerous other 
local tournaments in the Pacific Northwest 
during his chess "career." Currently he 
holds the official rating af candidate master. 
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OMPUTER CHESS 


By Jerry Wolfe 


The TI Video Chess Command Mod- 
ule is one of the programs now avail- 
able. It is a unique implementation since 
it is contained in 30K of ROM (no time- 
consuming cassette loading), can run on 
a “bare-bones” ТІ-99/4 (no disk drives 
or other peripherals are needed), uses a 
keyboard overlay to simplify commands, 
and has built-in chess clocks. This last 
feature is useful for users who wish to 
eventually play in chess tournaments 
where the use of chess clocks in manda- 
tory. Thus, playing under tournament 
conditions is actually now possible in 
the privacy of one's own home! 


Learning can 
progress much 
faster when a 
tireless, willing 


opponent is always 


ready to play! 


In this initial article, I'll look briefly 
at the main features of the video chess 
program, examine some of its strengths 
and weaknesses, and make some sugges- 
tions for using the program to learn 
chess. 

There are four main options avail- 
able for using the program. You can (1) 
play chess against the computer, (2) 
play against another human opponent, 
(3) set up a problem for the computer 
to solve, or (4) have the program play as 
many as ninc (!) opponents simulta- 
neously. In addition, games or positions 


may be stored on cassette—an especially 
useful feature for postal players, or 
players without enough time to finish 
their games in one sitting. 

When playing against the computer, 
you can control the playing characteris- 
tics of the program by choosing the ex- 
perience level (beginner, novice, or in- 
termediate), the time allotted to the 
computer for each move (30 seconds to 
200 seconds), and the style of play (nor- 
mal, defensive, or aggressive). The pro- 
gram also allows you to take back a 
move, ask for advice, have your move 
evaluated, or even switch sides! 

In the problem mode, you can ask 
the program to solve a mate in two, 
three, or four moves. This is, of course, 
a potentially valuable learning tool, but 
the program's versatility doesn't stop 
there: you can also set up any position 
and have the computer play a normal 
game starting from the given position. 

Based on many years of tournament 
experience, | would estimate the maxi- 
mum strength of the program to be 
slightly less than the average player in a 
typical chess tournament. This is supe- 
rior to probably 9096 of chess players as 
a whole! And presumably, stronger ver- 
sions of the program will be available 
in the future. To put this in perspective, 
the strongest chess-playing program in 
the world, running on the enormous and 
fast CYBER or CRAY computers, still 
does not play at the level of a human 
chess master. (It will, however, defeat 
99% of chess players as a whole!) 

As an educational tool, the video 
chess program is excellent. А beginning 
player can make rapid improvement in 
his game by adjusting the strength of 
the program as his own playing strength 
increases, If you're a new player, you 
should have at least one good book on 
chess that is designed for beginners. 
(There are many good ones on the mar- 
ket.) Then as you learn new ideas and 
techniques from reading, you can try 
them out against the computer imme- 
diately. For example, it is important for 
every player to master the basic check- 
mates—king and queen vs. king; rook 
and king vs. king; two bishops and king 
vs. king; etc. All good chess manuals dis- 
cuss these in detail. After reading about 
how to mate with king and rook against 
king, say, you can immediately try it 
out using the program. Learning can 
progress much faster when a tireless, 
willing opponent is always ready to play! 

The weakest part of the program is in 
the problem mode when asking for a 
mate in two, three, or four moves. For 
example, when І gave the program Prob- 
lem No. 1 (below), it worked for two 
and one half hours without coming to a 
conclusion. І finally turned it off. Апа І 
have had similar disappointing results 
with rather easy mates in two. Fortu- 
nately, this defect is not terribly impor- 
tant, and may.be alleviated in future 


versions of the program. The best use 


for this problem solving mode seems to Problem No. 1 
be in setting up positions from which White: Pawns: 
the computer will commence playing as Knights: 
in a normal game. (Note: you can do Bisho s: 
this to learn the basic checkmates men- во 8 
tioned previously.) Queen: 
In the next article І will report the King: : 
results of a yet-to-be-played match be- 
tween the Video Chess program and one Black: Pawns: 
of the best chess playing machines (the Knights: 
so-called "Boris" machine) which re- Bishops: 
portedly plays at a somewhat higher Rooks: 
level than the average tournament Queen. 
player. I’d also appreciate hearing any King: 
comments, experiences, or questions ` 


that you might have pertaining to the 
Video Chess program or chess in general. 
As a regular feature of this column, | 


will leave you with two problems to Problem No. 2 
solve. Solutions will appear in the fol- White: Pawns: 
lowing issue. Problem No. 1 comes Knights: 
from a game between two grandmasters Bishops: 
about sixty years ago. Problem No. 2 is Rooks: 
a famous position—especially memora- Queen: 
ble because after black made the beauti- King: 
ful winning move, spectators showered 
the playing stage with gold coins. As it Black: Pawns: 
turned out, however, they were not Knights: 
showing their admiration . . . but rather, Bishops: 
paying off their bets in disgust! а Rooks: 
Queen: 
King: 


White to move and checkmate in three moves 


Black to move and win (Black has a single crushing move) 


A2,B2,C2,F2,G2,H2 


A7,B7,C6,F7,G7,H7 
В8,Е4, 

CB , F8 

A8 , H8 

E5 

El 


A2 ,C2 ,F2 , G2 , H2 
None 

None 

C5,Fl 

G5 

Gl 


А7 , B7 ,E6, G7 , H7 
D4 

None 

H3 , F8 

cs 

G8 


Put аа IMAGE 
On Your TI-99/4 


With our exciting line of cassette programs 
that introduce ; you to the full range of 
color, sound, and computing power 
of your Home Computer. 


* Wildcatting — Drill for Oil ! 


© Strategy Pack 1— Includes both 
Roman Checkers and Frame Up 


* Wall Street Challenge— Play the 
Stock Market! 


* Tournament Brick Bat—Fast-action 
Skill Game 


e Mind Master — Classic strategy game 
Skill Builder 1 Includes both 
Bingo Duel & Number Hunt 


Plus $2.00 shipping/handling. 


$14.95 
$19.95 


$14.95 
$19.95 


$14.95 
$19.95 


All cassettes professionally boxed with 
detailed instruction booklets. 


To order, or for additional information: 


Image Computer Products, Inc. 
615 Academy Drive, Dept. DS-5 
Northbrook, IL 60062 

Tel. 312-564-5060 


Advertise In 


=] сар. 


magazine" 


Call or Write 
for 


Rate Card Today! 


99'er Magazine / Ad. Dept. 
2715 Terrace View Drive 
Eugene, Oregon 97405 
(503)-485-8796 
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4K bytes ROM 
containing monitor and 
symbolic assembler/ 
University 


2K bytes expansion 
EPROM socket 
University 


Audio Cassette 
interface 


Sound disk for 
audio response and 
lab experiments 


Optional interface 
allows Н5232 or 
TTY terminal to be 
connected. 


10 digit 

7 segment display 
with 64 character 
buffer. 


TMS9980 16-bit CPU 


Memory and 
1/0' Expansion 


User 1/0 


TM 990/189 | 


тМ59901 parallel 
1/0 controller 


45 key alphanumeric 
keyboard. All keys ai 
dual function. Allows 
student to program in 
assembly language. 


1K bytes RAM expandable 
to 2K bytes 


User addressable 
LEDs. 


The Texas Instruments TM 990/189 
University Module 


omputer-assisted instruction (CAI) 
( continues to find exciting, new 

applications in many fields. Yet, 
in all the attempts by educators to pro- 
mote these glamorous applications and 
exotic uses, the most “logical” instruc- 
tional assistance that a computer can 
provide us with is often forgotten or 
largely ignored. І'т referring, of course, 
to using CAI to learn more about how 
computers themselves work. This is, in- 
deed, a most practical application, since 
it fosters the particular experience and 
knowledge that is absolutely essentia/ to 
the development of better CAI tools. As 
readers of this magazine undoubtedly 
know by now, our hardware focus is on 
the 16-bit TMS9900-family of micro- 
processors and its associated microcom- 
puter configurations. And although the 
Т!-99/4 is the most familiar 9900 con- 
sumer product, it is not the one best 
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configured for hands-on experience with 
hardware and software operation and 
design. The product that is best for this 
purpose is, in fact, the TM 990/189 
University  Module—a self-contained, 
single-board microcomputer system that 
is intended for use as a learning aid in 
the instruction of microcomputer fun- 
damentals, machine and assembly lan- 
guage programming, and microcomputer 
interfacing. 

In this introductory article, we'll 
take a brief look at the components of 
this system, and examine its suitability 
for classroom work, for an in-house in- 
dustrial trainer, and as an interactive 
private teacher for engineers or serious 
hobbyists. For Т 1-99/4 users interested 
in "getting into” assembly language pro- 
gramming and the "guts" of their ma- 
chines, we'll follow this article with a 
tutorial series on using this University 


By Gary M. Kaplan 


Module as both a teacher and an inex- 
pensive hardware and software develop- 
ment tool—one that can interface with 
other 990-series boards, as well as the 
ТІ-99/4 personal computer. Applica- 
tions, programs, and interfacing tech- 
niques from TM 990/189 users are most 
welcome. 

Those of you who have been yearn- 
ing to rip apart your personal computer 
and find out what makes it tick, now 
have a more convenient option with this 
magazine-size, non-enclosed microcom- 
puter board. Just about all the compo- 
nents found inside а ТІ-99/4 console are 
also found on this board—with the ma- 
jor exception of a video display pro- 
cessor chip. The layout, as seen from 
the above photo, is clean and unclut- 
tered, 

If you try to find the monstrous, 
64-ріп TMS9900 microprocessor (the 


one used in the TI-99/4) on the Univer- 
sity Module board, you'll soon discover 
that it isn’t there! Instead, the Universi- 
ty Module uses the TMS9980A, a 40-pin 
DIP package that is instruction-set com- 
patible (69 basic op codes) with the 990 
and 9900 family of minicomputers and 
microprocessors manufactured by Texas 
Instruments. It has a 16-bit CPU, but 
has a convenient 8-bit data bus (it 
doesn't have to be converted to 8-bits as 
does the TMS9900 for use in the 
TI-99/4), and an on-chip clock. The 
chip has been designed to minimize the 
system cost for smaller applications. 

The board also comes with 1024 
bytes of RAM (expandable on board to 
2048 bytes), 4096 bytes of ROM (ех- 
pandable on board to 6144 bytes) con- 
taining a monitor and symbolic assem- 
bler, а 16-bit programmable МО port 
and interrupt monitor (parallel 
TMS9901 chips), a 45-key alphanumeric 
keyboard, а ten-digit, sevensegment 
L.E.D. alphanumeric display, plus a pair 
of built-in programmable audiovisual 
peripherals (four L.E.D. indicators and a 
sound disc). 

Besides the board, thc University 
Module comes with a 300-page 7M 
990/189 Microcomputer User's Guide 
which provides all the circuit diagrams 
and schematics, timing charts, explana- 
tions of theory, interfacing options, 
troubleshooting suggestions, and opera- 
tional data that any user would want to 
know. The book is well organized and 
especially thorough. But the board and 
User’s Guide alone, “Чо not a University 
Module make...” Purchasers also re- 
ceive the 570-page {Introduction to 
Microprocessors—a tutorial text especial- 
ly written to satisfy textbook require- 
ments at universities, colleges, and tech- 
nical institutes for a three credit-hour 
course. The only other thing needed to 
get started is a power supply. Module 
users can provide their own, or purchase 
the TM 990/519 which connects to the 
University board with convenient snap- 
on connectors. 


A word about the tutorial text, 
Introduction to Microprocessors: Before 
receiving my copy, | was somewhat 
skeptical about the utility of a “college 
textbook” for a course that was sup- 
posedly capable of being “self-taught.” 
Traditional textbooks (more often than 
Га саге to remember) have frequently 
needed | willing — professors—standing 
ready in the wings—to "de-mystify" 
them. | was, however, pleasantly 
surprised by this one. Evidently, the 
three-year historical development of the 
course material (in industrial seminars 
and an SMU School of Engineering 
course) with ample opportunity for stu- 
dent feedback and suggestions, had a 
lot to do with this easy-to-understand 
text that finally emerged. The material 
is presented in an orderly, progressive 
manner—perfectly suitable for self-paced 
free-time study. Only a minimal back- 
ground in digital logic and computer op- 
eration is necessary. Students are taken 
on an exciting tour of microprocessor 
architecture, arithmetic logic, computer 
addressing and program development, 
assembly language, memory systems, in- 
put/output concepts and design, modu- 
lar programming, software engineering, 
and product development. 

In addition to the on-board RAM ex- 
pansion kit, there is an I/O expansion 
kit that provides the board with (1) an 
asynchronous communications control- 
ler with interface circuits for terminals 
that are either RS232C-compatible or 
use 20 mA current loops; (2) an on- 
board relay for the audio cassette inter- 
face that can control the tape recorder's 
motor drive; and (3) a bus expansion in- 
terface through which you can address 
up to 8192 bytes of off-board memory, 
and expand the CRU's (the communi- 
cation register unit of the microproc- 
essor) capability of accepting input 
from off-board devices. With the instal- 
lation of this 1/O kit—a very simple pro- 
cedure, with the sockets and removable 
jumpers already on-board—you can ef- 
fectively transform this microprocessor 
trainer into a development tool and 
real-world process control device сара- 
ble of doing many kinds of sensing and 
control with only minor additional 
circuitry. 

This brings us to the subject of pro- 
gramming languages. As mentioned ear- 
lier, the 4096-byte ROM contains a mon- 
itor and symbolic assembler. A user can 
program directly in TMS9900 assembly 
language through the 45-key, calculator- 
type alphanumeric keyboard (or with an 
external CRT or printer terminal if the 
МО kit has been installed). Even though 
there are only 45 keys, a shift function 
enables practically the full ASCII char- 
acter and control set to be represented 
(except for lowercase and the amper- 
sand (&) character). The UNIBUG mon- 
itor allows us to converse with the Sys- 
tem, so we can write better programs, 


and effectively debug them. UNIBUG 
gives us 16 commands and 7 I/O utilities 
—things like inspect/change functions 
for the CRU, status register, memory, 
workspace register, workspace pointer, 
etc. 

After a finished program runs cor- 
rectly in the on-board RAM, you can 
have it burned into EPROM (using a 
separate EPROM programmer), and plug 
it into the empty on-board EPROM 
socket. Although 2K of RAM or ROM 
doesn't seem like a lot of memory to a 
BASIC programmer with a 16K machine, 
remember that assembly is a low-level 
language that allows a programmer to 
communicate much more directly with 
the microcomputer through very com- 
pact instructions. And don't forget that 
the TM 990/189 also has the capability 
to address one block of off-board 8K 
RAM. 

The board was obviously designed 
with flexibility in mind, Write your own 
"exotic" language and operating system 
in assembly, burn it into one or two 
EPROMs, snap it into the board's 4K 
and 2K sockets, and you're off and run- 
ning with your own dedicated machine! 
Or, if you prefer a high-level language, 
you can buy TI's University BASIC (in 
6K of PROM). It has all the "software 
hooks" in it for interfacing with the 
ТМ59918 video display processor chip 
(the same one used in the Т1-99/4) to 
create sprites on a color TV or monitor. 
Note: ТІ also sells the TM990/189-1 
Packaged University Module. It has the 
expansion RAM and I/O kits installed, 
and comes with the BASIC in PROM. 
Purchasers of this configuration will 
have to buy separately the 4K ROM 
containing the UNIBUG monitor and 
symbolic assembler to program in as- 
sembly language. 

In the next issue, we will explore 
the world of 16-bit assembly language 
programming—with its powerful instruc- 
tion set, hardware multiply and divide, 
vectored interrupts, single-bit 1/0 ma- 
nipulation, parallel 1/O, and seven ad- 
dressing modes. And for readers with 
TI-99/4s, ГІЇ show you how to interface 
the two, and CALL your assembly sub- 
routines through Extended BASIC to 
have them run on the larger machine. 
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Involving Preservice Teachers 


With Microcomputers 


computers into the elementary 

and secondary schools is very much 
dependent on teacher preparation. Rec- 
ognizing this, Arizona State University 
(one of the largest teacher degree grant- 
ing institutions in the U.S.) has started a 
program to involve preservice teachers 
in microcomputer awareness activities. 
The first of these activities (for under- 
graduate elementary education majors 
in their mathematics methods class) is 
designed to familiarize the students with 
the College of Education’s microcom- 
puter laboratory. Since they are expec- 
ted to complete required tasks in the 
class, the microcomputer assignment 
was developed as part of the course task 
requirements. 

The assignment had the students (1) 
operate a microcomputer to run a pre- 
pared software program, and (2) enter a 
short BASIC program into the micro- 
computer. On the Texas Instruments 
Т1-99/4 microcomputer, the students 
used Number Magic for the first task. 
This pre-programmed, snap-in software 
module is designed for addition, sub- 
straction, multiplication, and division 
drills for ages six years and up. Hand- 
outs provide detailed instructions for 
operating the T1-99/4 and information 
on the Number Magic program including 
a description, objectives, background, 
sample runs, a lesson plan, and a student 
work sheet. Figure 1 contains parts of 
the task. 


р compu implementing micro- 


Part two of the task was to enter a BASIC 
program into a microcomputer, For the 
TI-99/4, we provided a simple entry- 
type program (printing the student's 
name and performing a computation), 
plus detailed instructions for accessing 
the computer (Figure 2). Students were 
required to report the output they ob- 
tained from the microcomputer, and 
answer several questions pertaining to 
the activity (Figure 3). 


College of Education /B225 Payne 
Arizona State University 
Tempe, AZ 85281 
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By Gary G. Bitter, Ph.D. 


The Task 
DESCRIPTION ... 


A game of varying difficulty, Number Magic provides enrichment, 
drill, and practice in basic mathematics. The student chooses the 
method of computation, the computer will present the problem on 
the screen, pause for student answer and respond to the answer, The 
computer will total the players score. 


OBJECTIVES... 


1. To build skill and speed in problem solving, 

2. To strengthen recall of basic mathematic equations. 

3. To develop strategies in working with certain number pairs, 
4. To make the drill of mathematics enjoyable to the user. 


BACKGROUND INFORMATION 


There are 3 activities in the Number Magic Module: Quick Quiz, 
Comp Quiz, and Electroflash. For “Comp Quiz” the player will be 
asked to either let the computer present ten problems randomly, or 
use the Memory Bank feature to store up to ten problem to answer 
... If the player chooses to let the computer give the problems, Ве 
or she can then choose the level of difficulty (easiest, simple, harder 
and hardest) and the kind of problem to be given (+, —, x, or +). 
In addition, the player has the option of supplying the missing num- 
ber or missing answer in the problems. Timer (to race against the 
clock) or no time limit can also be chosen when playing. For the 
Memory Bank feature, the computer will assist the player in filling 
the memory bank. Once all choices have been made the computer 
asks whether the player is ready to start. The player presses ENTER 
and the computer begins to present the problems. 


If the player is racing against the clock, a timer will be seen in the 
lower left corner. It begins at ten seconds and counts down. The 
time it takes to answer the problem correctly is the player's score for 
that problem. When incorrect answers are entered on the first or 
second attempt, the computer gives a "TRY AGAIN" message. On 
the third incorrect answer, the computer presents the correct answer 
and no score is given for that problem. 


If the player does not use the timer, the computer gives ten points 
when the answer is correct on the first attempt. On the second and 
the third attempts, seven points and four points are given respective- 
ly. After three tries, the computer will provide the correct answer 
with a *NO SCORE" message. On the first two incorrect answers, 
the computer gives a "TRY AGAIN" message. 


The computer keeps the total score and presents reinforcement at 
the end of the program. The computer then gives the player the 
chance to keep playing, select a new activity, replay the quiz, or stop 
the program. 


Figure 1 


The Task 
(D) LESSON PLAN... 


Present Number Magic as a fun way to drill and practice using vary- 
ing number sizes and functions. By introducing two opposite presen- 
tational levels, the children will be able to see an indication of the 
computer’s capacity within the game. At the start, divide the chil- 
dren into two teams. A running score can be kept on the blackboard. 
Allow captains of each team to also keep the score. (With younger 
children talley marks can be used.) Have one team decide whether to 
use the time limit; the next team can decide whether to fill in the 
answer or missing number, and so on, until each area has been chosen, 
As the computer presents each problem, a different member from 
each team will compete to see who can find the missing answer first. 
The first team member who answers the problem correctly gets the 
score associated with that problem. The game can be played until 
each member gets an opportunity to participate. Teams record their 
scores on the worksheet. 


Sample Number Magic Worksheet Entry : 


NAME: 


Against the clock: yes or no 

Filling in the: answer or missing number 
Select the problem: computer or memory bank 
Level of difficulty; 1 2 3 4 5 

Method of calculation: + — x = 

My score : 


Figure 1 (cont) 


EED 380 TEACHING MATH IN THE ELEMENTARY SCHOOL 


Assignment - Microcomputer - Programming 
Microcomputers - Any 


1. 


Follow the directions of the microcomputer called “Programming in 
BASIC.” 

. Type in this program (if you make a mistake type Return or Enter and 
retype the line). 


5 PRINT “YOUR NAME” 
10 LET A=3 
20  LETB-4 
30 LET C=A*B 
40 | PRINT “THE PRODUCT OF A AND В IS ”;C 
50 END 


(if an error, retype the line correctly and again type RUN ENTEN.) 
3. Туре RUN [ENTER 


4. On the back of this page write down the computer's output after you 
typed RUN. 


5. When done, turn off microcomputer and monitor (CRT or TV). 


Figure 2 


Complete the Following Questions 
What problems did you have? 
Were you successful? 


Which machine did you use? 


How can this activity be improved? 


Over 100 students were involved with 
the Number Magic module in the 1980 
fall semester. Ninety percent indicated 
having a successful experience. For most 
students this was their first experience 
with a microcomputer. 


Although this was a limited micro- 
computer experience, students neverthe- 
less became aware of the role of micro- 
computers in education. In fact, some 
students have decided to continue their 
study of microcomputers by spending 
their free time in the microcomputer 


laboratory. 
The task will continue to be used and 
upgraded each semester. Since the 


NCTM recommendations for the 80's in- 
clude the statement, "Mathematics pro, 
grams [should] take full advantage of 
the power of calculators and computers 
at all grade levels," microcomputer in- 
volvement for preservice teachers is ob- 
viously necessary. As one student com- 
mented, “І am sure І will be teaching 
with a microcomputer in the future. | 
am glad that І had an early awareness so 
! can adequately start getting prepared 
for its use in my classroom.” c 


Watch 
the Next 
Issue 


for the 
New Line 


of 
Software 
from 


————Ó 
INNOVATIVE PRODUCTS 
FOR TMS9900-BASED 
PERSONAL COMPUTING 
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Santa Paravia 
and 


By W.K. Balthrop 


“Power corrupts...’ Do you believe it? Sure, why 

not? It’s only an expression of human nature, isn’t it? 
But now let me pose the question in a slightly different 
way: If the power was placed in your hands, would it cor- 
rupt you? Or more precisely: If you were given the reins of 
absolute command, would you become an amoral and cal- 
culating tyrant, or a forceful-yet-benevolent ruler--an iron 
fist in a velvet glove? There’s only one way to find out. Let 
us give you that power by taking a trip back in time to 15th 
century Italy. And what better place is there for testing 
your abilities than in those turbulent, Machiavellian times 
when many ambitious rulers of small city-states vied for 
consolidation of power in hopes of eventually acquiring 
enough to become king. This time trip (or more literally, 
"power trip”) capability is provided by the people at Instant 
Software—the producers of Santa Paravia and Fiumaccio, a 
computer simulation program for your T1-99/4. 


ү" have heard it said тапу, many times before: 


Operation 


Santa Paravia and Fiumaccio is an interractive, non- 
graphic simulation for one to six players competing at one 
of four skill levels. Through clever economic and political 
management, each player attempts to amass enough points 
to become the first to build his or her city-state into a 
kingdom—before death intervenes. (Life was short in those 
days...) Players take turns ruling their individual cities. 
Each turn consists of four parts: (1) Harvest Phase--when 
labor, planting, feeding, warehousing, and buy/sell decisions 
must be made; (2) Tax and Justice Phase—allowing rulers to 
change tax rates and level of justice; (3) Public Works Phase 
—providing opportunities to invest in markets, palaces, ca- 
thedrals, the woo! industry, and equipping a portion of 
available serfs as soldiers; and (4) Display Phase—helping 
rulers plan strategy by displaying the present status of each 
kingdom-to-be. 


Documentation and Packaging 


The four-page typeset program documentation is very 
straightforward and easy to understand. Well-organized in- 
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structions allow even a first-time player to understand what 
is happening throughout his or her turn. Strategy tips are 
liberally sprinkled throughout, and are indeed more than 
welcome in a game with as many decisions to be made as 
this one. 

The cassette and documentation are packaged in a small, 
two-color cardboard box. Along with it comes Instant 
Software's policy of accidental erasing: They'll redo your 
cassette for anominal service charge of $2. This is one com- 
mon-sense practice I’d definitely like to see more of in the 
software industry. 


Performance and Engrossment 


The first time | played Santa Paravia, | was immediately 
impressed with the detail for accuracy and provision for 
realistic interaction that were built into the program, The 
game is well organized, and allows players to concentrate 
on strategy, rather than having to keep track of a super- 
abundance of rules (that other games of this type frequent- 
ly employ). Strategy can, in fact, become quite complicated, 
but the program thoughtfully provides each player with the 
ability to experiment with different decisions and compare 
outcomes. For example, after making the decision to in- 
crease one of the tax rates, the menu screen will display the 
updated figures; a player can then go back and change the 
decision if it turned out to cause unfavorable results. This 
nice feature prevents one bad, irretrievable move from 
“ruining the game." We'd all be better off if present-day 
politicians had this option! 

Гуе never had occassion to become bored when running 
this simulation. And, although it’s not the type of program 
fraught with engrossing visual action, Santa Paravia will 
keep you constantly thinking and wondering “What і... М 


Santa Paravia and Fiumaccio 
ТІ BASIC; 16K 
$9.95 (Cassette) 
Instant Software 
Peterborough, NH 03458 


advoCAIte Course 
Authoring Guide : 
A Preliminary Look 


By Marilyn Latham 
Gary G. Bitter, Ph.D. 


College of Education/B225 Payne 
Arizona State University 
Tempe, AZ 85281 


A new alternative now exists for educators without computer 
programming skills who, nevertheless, want to produce CAI (Com- 
puter Assisted Instruction) course material. eduCAltor, inc. of 
Hudson, Massachusetts, offers a system of programs on 5%” floppy 
diskettes designed to direct the teacher through a series of instruc- 
tions for creating his or her own software. This step-by-step proce- 
dure, the “адуоСАПе Course Authoring Guide,” allows a teacher 
to use music, color, and graphics (eventually, animated graphics), 
in developing curriculum. 

It appears that the advoCAlte system will find a comfortable 
niche in the educational community. Many schools are discovering 
that CAI courseware available from computer dealers and software 
clearinghouses is not suitable for their particular needs. The fear 
that many teachers have for "complicated computer courses" is 
another factor contributing to the delay in getting CAI into the 
classroom. advoCAlte addresses itself to both of these concerns. 

The advoCAlte system consists of Texas Instruments ТІ-99/4 
personal computer, color monitor, disk controller, three disk 
drives, one Disk Manager Command Module, a three-ring binder 
(of approximately 100 pages), and seven floppy disks containing 
the programs and file space. 

One of the programs automatically formats the material that 
will appear in the finished courseware. The five choices consist of 
(1) Text, (2) True-False, (3) Multiple Choice, (4) Match, and (5) 
Completion. Course authors can also choose from 185 graphics 
patterns stored in the "Permanent Graphics Dictionary,” and use 
them in the artwork design for cach frame. Original drawings may 
be added to the existing designs. Music may also be added to the 
frames by exchanging music notation for numbers represented on 
each line of the treble and bass clefs. The numbers are assigned to 
note values for establishing the sound, chords, and duration of 
tones. The result: A knowledge of music theory is not required for 
writing songs in this courseware! 

The most difficult part of working with advoCAlte is learning 
how to properly use the disk drives. It does take some time. Fur- 
thermore, even with this tool, the amount of time required to ac- 
tually produce finished courseware is something to be considered. 
The first-time user should be prepared to spend many hours review- 
ing the instructions and setting up the sequence of screen numbers. 

Since the finished, “customized” programs can be saved and 
transported on floppy disks, the large amount of development 
time can be recovered, in part, through curriculum exchanges with 
other schools or institutions. The possibilities of such applications 
are exciting. 


«^ Watch for an in-depth review in the 
July/August issue of 99'er Magazine. 


Personal 


Computing 
To Aid The 
Handicapped 


The first national search for ideas 
and inventions through which the 
full spectrum of personal computing 
technology can be harnessed to assist 
the handicapped has been announced 
by The Johns Hopkins University. 

The effort will be highlighted by 
a national competition for ideas, de- 
vices, methods, and computer pro- 
grams to help handicapped people 
overcome difficulties in learning, 
working, and successfully adapting to 
home and community settings. Cate- 
gories that may be addressed include 
computer-based aids for the blind, 
deaf and mentally retarded; for indi- 
viduals with learning disabilities, 
neurological or neuromuscular con- 
ditions; and the orthopedically handi- 
capped. 

One hundred awards will be made, 
including а $10,000 grand prize, 
personal computer equipment, other 
cash prizes, computer training, and 
certificates of merit. Entries will be 
sought from computer specialists, 
full-time high school and college 
students, and from interested people 
generally, including those with handi- 
caps. Regional and national awards 
will be made in all categories. 

Paul L. Hazan, director of the Per- 
sonal Computing to Aid the Handi- 
capped project, said the competition 
is a challenge to the American people 
to use their conceptual skills in bring- 
ing forth practical aids based on com- 
puter technology that will help an 
individual or group of people with a 
handicap. “Just as important will be 
the opportunity provided the in- 
ventors and developers to make con- 
tact and form partnerships with the 
handicapped in a way that can lead 
to wide acceptance and use of the 
new computing technology" Hazan 
stressed. 

Contestants will have until June 30, 
1981 to prepare and submit their en- 
tries. To obtain additional informa- 
tion including a descriptive flyer and 
contest application, write to Personal 
Computing to Aid the Handicapped, 
Johns Hopkins University, P.O. Box 
670, Laurel, Maryland 20810. Фо 
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Spelling Flash 


By Regena 


“Spelling Flash” was designed to help students review 
their weekly spelling lists. This program does not use the 
speech synthesizer. 

First the spelling words need to be typed in with DATA 
statements, starting with statement number 380. The words 
will be read as string variables. They may be entered as sep- 
arate statements for each word, or several words may be 
listed separated by commas in each DATA statement, 
Words in this context may, of course, also consist of phrases 
or names with imbedded spaces or other special characters. 
Such phrases must be enclosed in quotes. Typing in ZZZ 
after the last word will prevent a data error message 
after the word list is used up. 

The screen is cleared and a spelling word flashed on the 
screen. After a short delay the word is cleared and the 
student is asked to type in the spelling word. The end of 
the word is signalled by pressing the ENTER key. Positive 
reinforcement is given with some sounds and the statement, 
"YOU SPELLED IT RIGHT !!” If the word is incorrectly 
spelled the student must try again until it is correct. 

The screen is cleared and the next word is flashed. The 


REM XEXRiEiiTitiikifirt 


О REM x * 


REM *SPELLING FLASH® 
REM % 1 
REM хараал 41585443 
КЕМ 

РЕМ ву REGENA 

REM 99°ER VERSION 5.81.1 
CALL CLEAR 


О PRINT “SPELLING FLASH"::t: 


READ WORDS 

IF WORD$-"ZZZ"THEN 410 
PRINT "SPELL ";WORD$ 
GOSUB 540 

PRINT "SPELLING WORD:" 
INPUT WS 

IF WORD$-W$ THEN 290 


PRINT ::"SORRY-PLEASE TRY AGAIN":: 


вото 220 

CALL SOUND($500,-1,2) 

CALL SOUND (500, -2,2) 

PRINT ::"YOU SPELLED IT RIGHT!!" 
GOSUB 340 

GOTO 200 

FOR DELAY-1 TO 800 


O NEXT DELAY 


program will go through the list of words once. The pro- О БАСЫ CREAR 
gram тау be saved on cassette tape for use each day by the о RETURN 
student. Each week the data statements may be changed for DATA TIGER, BEHAVE, FEGIN, "JOHN ADAMS" 
the new list of spelling words. DATA TOMORROW, OZONE, SPRIG, GDOSE 
Н рата xi ER, À As geez 
If the delay is too long or too short, the number “800” о ENN CBE COVER анн раат 


in Statement 340 may be adjusted. т 


Сомғатев Аге» INSTRUCTION 
DESIGN WORKSHOP 
- The Definitive CAI Course - 


BOSTON — Park Plaza Hotel — June 1-5 


Each Participant Will Design and Write at Least 2 CAI Lessons, 
And Have Hands-On Use of an Authoring System. 
| co-sponsored by: Ware Associates, бегу Associates, eduCAltor, inc. 
ENROLLMENT LIMITED TO 16 


$670 for 2nd 
Educational Discount Available 


Price рег Enrollee: $715 for 1st 


Wy ГІ Please Bill Our Firm. Purchase Order No. 
/ N E | do not have a detailed outline. Please send one to my attention. 
ware associates 


A DIVISION OF WIA мс 


$645 for subsequent 


ГІ Enrollment Feets) in the amount of $ — — — — —— enclosed. 


1 understand that | can cancel any confirmed registrations up to 5 work- 
ing days prior to the course starting date. Cancellations after that date 
are subject to a $50 service charge and any reservations not cancelled at 


38 Main Street, Hudson, MA 01749 (617) 562-6921 D А й 
least 3 working days prior to the course starting date are subject to 


Course Title - payment of the entire fee. 
Course Location 
Course Dates Name 
Please enroll the following participants Signature 
Name Title Company Title 


= Address 


Zip Phone 
Ware Associates reserves the right to cancel the course 
or amend the syllabus. 
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MINDSTORMS 


Children, Computers and Powerful Ideas 


By Seymour Papert 


All of us, professionals as well as lay- 
men, must consciously break the habits 
we bring to thinking about the compu- 
ter. Computation is in its infancy. It is 
hard to think about computers of the 
future without projecting onto them 
the properties and the limitations of 
those we think we know today. And 
nowhere is this more true than in imag- 
ining how computers can enter the 
world of education. It is not true to Say 
that the image of a child's relationship 
with a computer | shall develop here 
goes far beyond what is common in to- 
day's schools. My image does not go be- 
yond: It goes in the opposite direction. 


In many schools today, the phrase 
“computer-aided instruction” means 
making the computer teach the child, 
One might say the computer is being 
used to program the child. In my vision, 
the child programs the computer and, in 
doing so, both acquires a sense of mas- 
tery over a piece of the most modern 
and powerful technology and establishes 
an intimate contact with some of the 
deepest ideas from science, from ma- 
thematics, and from the art of intellec- 
tual model building. 

| shall describe learning paths that 
have led hundreds of children to becom- 
ing quite sophisticated programmers. 
Once programming is seen in the proper 
perspective, there is nothing very sur- 
prising about the fact that this should 
happen. Programming a computer means 


Text excerpted and photo reprinted from 
Mindstorms by Seymour Papert, published by 
Basic Books, inc., New York 10022. Copyright 
1980, Basic Books, Inc. Used with permission, 
а ДА А 


nothing more ог less than communica- 
ting to it in a language that it and the 
human user can both “understand,” 
And learning languages is one of the 
things children do best. Every normal 
child learns to talk. Why then should a 
child not learn to “talk” toa computer? 


п я 


Іп ту vision, the child 
programs the computer 
and, in doing so, both 
acquires a sense of mastery 
over a piece of the most 
modern and powerful 
technology and establishes 
an intimate contact with 
some of the deepest 

ideas from science, 

from mathematics, and 
from the art of 
intellectual model 
building. 


n 


There are many reasons why some- 
one might expect it to be difficult. For 
example, although babies learn to speak 
their native language with spectacular 
ease, most children have great difficulty 
learning foreign languages in schools and, 
indeed, often learn the written version 
of their own language none too success- 
fully. Isn’t learning a computer language 
more like the difficult process of learn- 


ing a foreign written language than the 
easy one of learning to speak one’s own 
language? And isn’t the problem further 
compounded by all the difficulties most 
people encounter learning mathematics? 

Two fundamental ideas run through 
this book. The first is that it is possible 
to design computers so that learning to 
communicate with them can be a natu- 
ral process, more like learning French 
by living in France than like trying to 
learn it through the unnatural process of 
American foreign-language instruction 
іп classrooms. Second, learning 10 
communicate with a computer may 
change the way other learning takes 
place, The computer can be a mathemat- 
ics-speaking and an alphabetic-speaking 
entity. We are learning how to make 
computers with which children love to 
communicate. When this communica- 
tion occurs, children learn mathematics 
as a living language. Moreover, mathe- 
matical communication and alphabetic 
communication are thereby both trans- 
formed from the alien апа therefore 
difficult things they are for most child- 
ren into natural and therefore easy ones, 
The idea of “talking mathematics” to a 
computer can be generalized to a view 
of learning mathematics in “Mathland”; 
that is to say, in a context which is to 
learning mathematics what living in 
France is to learning French. 


People often ask whether in the fu- 
ture children will program computers or 
become absorbed in pre-programmed ac- 
tivities. The answer must be that some 
children will do the one, some the other, 
some both and some neither. But which 
children, and most importantly, which 
social classes of children, will fali into 
each category will be influenced by the 
kind of computer activities and the kind 
of environments created around them. 

As an example, we consider an activi- 
ty which may not occur to most people 
when they think of computers and chil- 
dren: the use of a computer as a writing 
instrument. For me, writing means mak- 
ing a rough draft and refining it over a 
considerable period of time, My image 
of myself as a writer includes the expec- 
tation of an "unacceptable" first draft 
that will develop with successive editing 
into presentable form. But І would not 
be able to afford this image if І were a 
third grader. The physical act of writing 
would be slow and laborious. І would 
have no secretary. For most children re- 
writing a text is so laborious that the 
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Figure 10с Bugged Man 


ment we contrast his program with a 
different strategy of programming known 
as "structured programming.” Our aim 
is to subdivide the program into natural 
parts so that we can debug programs for 
each part separately. In Keith's long, 
featureless set of instructions it is hard 
to see and trap a bug. By working with 
small parts, however, bugs can be con- 
fined and more easily trapped, figured 
out. In this case a natural subdivision is 
to make a program to draw a V-shaped 
entity to use for arms and legs and an- 
other to draw a square for the head. 
Once these "subprocedures" have been 
written and tested it is extremely easy 
to write the “superprocedure” to draw 
the stick figure itself. We can write an 
extremely simple program to draw the 
stick figure: 


TO MAN 

VEE 
FORWARD 50 
VEE 
FORWARD 25 
HEAD 

END 


This procedure is simple enough to grasp 
as a whole. But of course it achieves its 
simplicity only by making the assump- 
tion that the commands VEE and HEAD 
are understood by the computer. If they 
are not, the next step must be to define 
VEE and HEAD. We can do this in the 
same style of always working with a pro- 
cedure we can understand as a whole. 
For example: 


TO VEE 
RIGHT 120 
LINE 50 
RIGHT 120 
LINE 50 
RIGHT 120 
END 


(In this program we assume we have de- 
fined the command LINE, which causes 
the Turtle to go forward and come back.) 


To make this work we next define LINE: 


TO LINE :DISTANCE 
FORWARD :DISTANCE 
BACK :DISTANCE 
END 


Since the last procedure uses only innate 
LOGO commands, it will work without 
further definitions. To complete MAN 
we define HEAD by: 


TO HEAD 
RIGHT 45 
SQUARE 20 
END 


Keith, the author of the nonstruc- 
tured MAN program, had been exposed 
to the idea of using subprocedures but 
had previously resisted it. The “straight- 
line" form of program corresponded 
more closely to his familiar ways of do- 
ing things. He had experienced no com- 
pelling need for structured programming 
until the day he could not debug his 
MAN program. Іп LOGO environments 
we have seen this happen time and again. 
When a child in this predicament asks 
what to do, it is usually sufficient to 
say: "You know what to do!" And often 
the child will say, sometimes triumphant- 
ly, sometimes sheepishly: “І guess І 
should turn it into subprocedures?" The 
“right мау” was not imposed on Keith; 
the computer gave him enough flexibili- 
ty and power so that his exploration 
could be genuine and his own. q 


If you've found these excerpts stimu- 
lating, you will definitely want to 
read the entire book. See the 99'er 
Bookstore section (p. 32-35) for 
price and ordering information. 
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LOGO is the name of a philosophy of education in a growing family of computer 
languages that goes with it. Characteristic features of the LOGO family of lanuages 
include procedural definitions with local variables to permit recursion. Thus, in 
LOGO it is possible to define new commands and functions which then can be used 
exactly like primitive ones. LOGO is an interpretive language. This means that it 
can be used interactively. The modern LOGO systems have full list structure, that is 
to say, the language can operate on lists whose members can themselves be lists, lists 
of lists, and so forth. 


Some versions have elements of parallel processing and of message passing in or- 
der to facilitate graphics programming. An example of a powerful use of list struc- 
ture is the representation of LOGO procedures themselves as lists of lists so that 
LOGO is not a “toy,” a language only for children. The examples of simple uses of 
LOGO in this book do however illustrate some ways in which LOGO is special in 
that it is designed to provide very early and easy entry routes into programming for 
beginners with no prior mathematical knowledge. The subset of LOGO containing 
Turtle commands, the most used “епігу route" for beginners, is referred to in this 
book as “TURTLE TALK” to take account of the fact that other computer lan- 
guages, for example SMALLTALK and PASCAL, have implemented Turtles on their 
systems using commands originally developed in the LOGO language. The TURTLE 
TALK subset of LOGO is easily transportable to other languages. 


it should be carefully remembered that LOGO is never conceived as a final pro- 
duct or offered as “the definitive language.” Here І present it as a sample to show 
that something better is possible. 


Precisely because LOGO is not a toy, but a powerful computer language, it re- 
quires considerably larger memory than less powerful languages such as BASIC. 
This has meant that until recently LOGO was only to be implemented on relatively 
large computers. With the lowering cost of memory this situation is rapidly chang- 
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Students do their class assignments 


on paper in the usual way.... 
and then can use the Homework Helper 


(Л 
КА 


to quickly correct their assignments. 
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By Regena 


FRACTIONS 


he “Homework Helper” series is 
T designed to quickly give answers 

to students checking their assign- 
ments. It is not meant to be a tutorial; it 
does not teach concepts nor quiz the 
student, Rather, it gives the answers to 
problems without showing all the inter- 
mediate steps. 

The students are encouraged to do 
their class assignments on paper in the 
usual way, writing the problem down 
and working the problem step-by-step. 
Then, they can use the “Homework 
Helper” to quickly correct their assign- 
ments. 

This program, involving fractions, is 
for correcting the homework problems 
of elementary school math students 
(4th, 5th, and 6th graders). Written in 
ТІ BASIC, it employs color graphics and 
sound, and is user interactive. There are 
seven sections—each introduced with a 
simple color representation of what that 
section is doing with fractions. Musical 
phrases from Mendelssohn, Handel, and 
Beethoven are also present. 


1. Equivalence. Two fractions are of the 
form ^ = с. Any one of the four posi- 


tions can be the unknown. The user des- 
ignates the unknown, and inputs the 
three given values. The computer finds 
the unknown and prints the equivalent 
fractions. A student can also use this 
section to find equivalent ratios. 


2. Simplification. The user inputs a nu- 
merator and a denominator. The com- 
puter simplifies (reduces) the fraction or 
tells if it cannot be simplified. 

3. Multiplication. The user designates 
the number of fractions to be multiplied, 
then enters the numerator and denomi- 
nator for each one. The computer mul- 
tiplics them and simplifies the final frac- 
tion. 

4. Division. Two fractions are entered; 
the first is then divided by the second, 
and the answer is simplified. 

5. Addition—Like Denominators. The 
user specifies the number of fractions to 
be added, the common denominator, 
and then enters the numerators. The 
computer adds the numbers and simpli- 
fies the result. 


6. Addition—Unlike Denominators, This 
section may be used to add fractions 
with like or unlike denominators. The 
user specifies the number of fractions 
up to 5 (which should be sufficient for 
elementary school mathematics), and 


then inputs the numerator and denomi- 
nator of each. The computer adds the 
fractions and simplifies the results. A 
student can also use either Section 5 or 
6 for subtraction problems by entering a 
negative numerator, 


7. Comparisons. Up through ten frac- 
tions may be compared on a number 
line. The user enters the number of frac- 
tions to be compared (up to ten), and 
then enters the numerator and denomi- 
nator of each. The computer then ar- 
ranges the fractions from the smallest to 
the largest and prints them. 

To stop any section of the program, 
press SHIFT C. To restart, enter RUN. 


Efficiency Techniques 


Simplifying Fractions 

One basic technique of simplifying 
fractions is to start with the numerator 
as the first factor and see if it can be di- 
vided evenly into the denominator, If it 
can, both numerator and denominator 
are divided by that factor to immediate- 
ly yield the simplified fraction. If the 
denominator cannot be cvenly divided, 
the factor is reduced by опе, and the 
numerator and denominator are tested 
to see if they are divisible by the new 
factor. 
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In each successive test, the factor is 
reduced by one. When both numerator 
and denominator can finally be evenly 
divided by the factor, that factor is the 
greatest common factor. The numerator 
and denominator are then divided by 
this factor to yield the reduced fraction. 

For larger numbers, the technique 
can take a lot of time. In this program, 
the algorithm has been made more effi- 
cient by first checking to see which is 
smaller, the numerator or the denomina- 
tor. In improper fractions the denomi- 
nator will be smaller. The starting factor, 
PLIM, is set equal to the smaller number 
(Statements 1380 to 1410). 

Another efficiency technique is to 
eliminate testing all even factors if cither 
numerator or denominator is an odd 
number, This technique cuts the search 
time in half. In Statements 1420 to 
1450 the step size, S, is set equal to —2 
if either the numerator or the denomi- 
nator is odd; S is set equal to —1 if both 
numerator and denominator are even 
numbers. 

The simplifying algorithm is imple- 
mented with a FOR-NEXT loop. The 
starting trial factor is reduced by the 


step size, S, to a lower limit of 2 in 
line 1460. 

Within the loop, Statements 1460 to 
1510 set A-NS/P (where NS is the 
numerator) and set B-DS/P (where DS 
is the denominator). Then they check 
to see if A-INT(A); if equal, then 
B=INT(B) is checked. If both statements 
are true, the simplified fraction is A/B. 
Otherwise, P is incremented by S, and 
the loop continues. If the lower limit is 
reached without finding a successful 
factor, the user is notified that the frac- 
tion cannot be simplified (Statements 
1520-1540). 

When combining several fractions in 
multiplication or addition, another effi- 
сіепсу technique sets the starting factor 
equal to the largest denominator of the 
original fractions (Statements 2250- 
2340). The common denominator may 
be much larger than the original denom- 
inators, but the largest factor will always 
be the largest original denominator. 


Comparisons 


The schoolroom technique for com- 


paring fractions is to find the common 
denominator and then compare the ad- 
justed numerators. This technique is far 
too slow, especially when comparing 
many fractions and/or fractions with 
large numbers. А very fast technique 
which achieves the same end result is 
to compute and compare the decimal 
equivalents of the fractions. 

As the fractions are read in, the nu- 
merator NNN (1) is divided by the de- 
nominator DDD (T) and stored as a dec- 
imal fraction in two identical arrays, 
FRC (I) and FRD (1) (Statements 5170- 
5230). A standard sort routine sorts 
the first array FRC from the smallest to 
the largest. The subscripts are changed 
as the decimal fractions are arranged in 
order (Statements 5250-5330). 

The first element of FRC is compared 
with each element of the second array, 
FRD. When a match is made, the sub- 
script value J is used to retrieve the nu- 
merator and denominator of the corre- 
sponding fraction for printing. The pro- 
cess is repeated in order for each element 
in the FRC array (Statements 5340- 


5390). a 


Homework Helper : Fractions 


Program Explanations 


Line Nos. 
160-170 


180-250 


260-390 
410-550 


580-640 
670-730 


740-890 
900-960 
970-1190 


200-1230 
240-1310 


1320-1350 
360-1370 
1460-1540 
1550-1620 
630-1650 
1660-1710 
1720-1770 
780-1800 
810-1880 
1890-1930 
940-2150 
2160-2360 


2370-2430 
2440-2470 
2480-2490 
2500-2540 
2550-2620 
2630-2680 
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Sets Т and T2 for the time in the music state- 
ments, 

Defines characters and colors in four different 
character sets for use in graphics. 

Prints title screen, “HOMEWORK HELPER”. 
Prints “FRACTIONS” and blinks an outline 
of asterisks around it. 

Prints the menu screen for the seven sections 
of the program. 

The user presses a key to choose which of the 7 
sections is wanted, and the computer branches 
to that selection. 

Prints the screen for Equivalence. 

Asks for the unknown, A, B, C, or D. 
Depending on which is the unknown, asks for 
the given values and calculates the unknown. 
If the unknown is not a whole number, it will 
be rounded to two decimal places. 

Prints the equivalent fractions. 

Asks if there is another problem or to stop. If 
“27 is pressed, the menu screen is returned. 
Prints screen for Simplifying. 

Asks for the fraction. 

Simplifies and prints the result. 

Continue or go to menu screen, 

Prints screen for Multiplying. 

Asks for the fractions. 

Multiplies the fractions. 

Prints the problem and the simplified answer. 
Continue or go to menu screen. 

Subroutine for printing the problem, 
Subroutine for simplifying and printing. 
Subroutine for sorting and simplifying. These 
three subroutines are used for simplifying and 
printing in other sections of the program also. 
Prints screen for Dividing. 

Asks for the two fractions. 

Performs division. 

Prints problem and simplified solution. 
Continue or go to menu screen. 

Prints screen for Adding with like denomina- 
tors. 
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2690-2760 
2770-2820 
2830-2900 
2910-2960 


2970-3090 
3100-3150 


3160-3230 
3240-4090 
4100-5020 
5030-5120 
5130-5230 


5240-5330 
5340-5390 
5400-5470 
5480-5670 


Asks for the fractions апа addsthe numerators. 
Prints the problem and the simplified sum. 
Continue or go to menu screen. 

Prints screen for Adding with unlike denomi- 
nators. 

Asks for the fractions and calculates a com- 
mon denominator. 

Adds the adjusted numerators and prints the 
problem and the simplified result. 

Continue or go to menu screen. 

Sound subroutines— musical phrases. 

Draws color graphics for each title screen. 
Prints screen for Comparisons. 

Asks for fractions and converts fractions to 
decimals. 

Sorts fractionsfrom the smallest to the largest. 
Prints fractions in order. 

Continue or go to menu screen, 

Music and graphics for Comparisons. 


To stop the program, press SHIFT C (BREAK). 
For the student's convenience, at the end of 
each problem he can choose to do another 
problem of the same type or go to the menu 
screen and do a problem of a different type. 
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i i 5020 CALL HCHAR(10,14,144,3) 5450 CALL KEY (0,K, STATUS) 

Fractions, continued . . . $030 CALL HCHAR(9, 13, 144, 4) 5460 IF STATUS<=0 THEN 5450 
5040 CALL HCHAR(S, 12, 144, 4) 5470 CALL CLEAR 

4610 CALL VCHAR(11,9,152,4) 5050 RETURN 5480 IF K=49 THEN 5060 

4620 CALL VCHAR(10,155128,4) 5050 DATA 67,79, 77,80, 65,82, 73, 83,79, 5490 IF K-50 THEN 590 

4630 CALL VCHAR(10, 14,128, 4) 78,83, 32 $500 вото 5450 

4640 CALL НСНАЯ (14, 15, 152, 2) 5070 RESTORE 5060 5510 CALL SOUND (400, 530, 2, 262,5) 

4650 CALL VCHAR(10,18,128,2) 5060 FOR Y=11 TO 22 5520 CALL VCHAR(4,8, 136,3) 

4660 CALL VCHAR(10,19,128,2) 5050 READ L 5550 CALL VCHAR(4,9, 156, 5) 

4670 CALL VCHAR(12,18,152,3) 5100 CALL HCHAR(14,Y,L) 5540 CALL SOUND(100, 330, 2) 

4680 CALL УСНАН (12, 19,152,5) 5110 NEXT У 5550 CALL HCHAR(7,8, 144, 2) 

4670 CALL УСНАЕ(10,25, 128,3) 4120 совив 5510 5560 CALL SOUND(100, 262, 3) 

4700 CALL VCHAR(10;245 128,5) 5130 DIM NNN(10) ,DDD(10) ,FRC(10) ,FRD(10) 5570 CALL SOUND (400, 330, 1) 

4710 CALL VCHAR (13,255 152,2) 5140 PRINT “THIS ARRANGES FRACTIONS” 5580 CALL VCHAR(4, 15, 128, 4) 

4720 CALL VCHAR(K13,24,152,2) 5150 PRINT "FROM SMALLEST TO LARGEST.":: 5590 CALL VEHAR (В, 15, 152, 2) 

4730 RETURN 5160 INPUT “HOW MANY FRACTIOUNS?":NF 5600 CALL SOUND (100, 530, 2) 

4740 CALL УСНАА (10,8,128,4) — $156 IF МЕСІЇ THEN 5200 5610 CALL SOUND(100, 262, 5) 

4750 CALL VCHAR (14,8, 136,3) 5180 PRINT “SORRY; UP TO 10 ONLY." 5620 CALL SOUND(400, 330, 1) 

4760 CALL УСНАА (10,12,144,2) 5190 БОТО 5150 5650 CALL УСНАА (4,25, 152, 5) 

4770 CALL VCHAR(10,13,144,2) 5200 FOR 1=1 TO NF 5640 CALL VCHAR(4, 24, 152,3) 

4780 CALL VCHAR(12,12,128,3) 5210 PRINT а: "FRACTION “31 5550 CALL SOUND (200,392, 5) 

4790 CALL VCHAR(12,13,128,3) 5220 INPUT = NUMERATOR: "1 NNN CI? 5650 CALL VCHAR(7,23, 136, 5) 

4800 CALL HCHAR(10,17,136,3) 5250 INPUT = DENOMINATOR: "sDDD (1) 5670 CALL SOUND(200,524,3) 

4810 CALL HCHAR(11,17,152,3) 5240 РЕСІ) =NNN(I) /DDD(1) 5680 CALL VCHAR(7, 24, 136, 3) 

4820 CALL HCHAR(12,17,152,3) 5280 FRD(1) «ЕСКІ» 5690 CALL SOUND (400, 560, 1) 

4850 CALL HCHAR(13,17,152,3) 5250 NEXT 1 5700 RETURN 

4840 CALL VCHAR(10,23,152,2) 5270 PRINT 1101 

4850 CALL VCHAR(10,24,152,2) 5260 SW=0 

4860 CALL VCHAR(12,23,144,4) 5290 FOR I=1 TO NF-1 

4870 CALL VCHAR(12,24,144,4) 5500 IF FRC(1)<=FRC(1+1) THEN 5550 

4880 RETURN 5510 FFzFRC(I) 

4890 CALL НСНАЯ (4, 15, 128, 2) 5520 FRC(I) #FRO(1+1) 

4900 CALL HCHAR(S,14,128,32 $330 FRC(I+1)=FF 

4910 CALL HCHAR(6,13,128,4) 5540 биєі 

4920 CALL HCHAR(7,13,128,4) 5550 NEXT I 

4930 CALL HCHAR(4,17,136,2) 3 $350 IF SW=1 THEN 5280 

4940 CALL HCHAR(S,17,136,3) || 5370 FOR 1-1 TO NF 

4950 CALL НСНАЯ (6, 17,135,4) 5580 FOR Jet TO NF 

4960 CALL НСНАВ(7,17,156,4) 5590 IF FRCO(1)=FRD(J) THEN 5410 

4970 CALL НСНАВ (В, 17, 152,4) 5400 NEXT J Bookstore 

4980 CALL HCHAR(9,17,152,4) 5410 PRINT Ір" 0 ";NNN(J)3"/";DDD(J) 

4990 CALL НСНАВ (10, 17,152,5) 5420 NEXT I 

$000 CALL HCHAR(11,17,152,2) 5450 PRINT i::"PRESS i FOR NEXT PROBLEM" (p. 32, 33, 34, 35) 

5010 CALL HCHAR(11,15,144,2) 5440 PRINT "PRESS 2 TO STOP" 
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Telecommunicating with the TI-99/4 
Micro Bartender 

CAI for Engineers 

Let's Learn Notes 

Typing Tutor 

Pre-Schoolers and the TI-99/4 


Software Language Conversions 

А Look at Bit Pads, CRTs & Modems 

Marinchip Systems' TMS9900 Boards 
& Super-Fast OBASIC 
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And Many Additional Surprises... 
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The Way It Works: 
A Block Diagram of the TI-99/4 
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From Texas Instruments Home Computer Technical Data 
Copyright 1980, Texas Instruments Incorporated. 
Used by permission, 
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DIGITAL COMPUTER CASSETTES 
with LIBRARY ALBUM 


е High-Quality BASF Tape in a 5-Screw 
Cassette Housing for Data Integrity 


е Secure Storage & Quick Convenient Retrieval 
with Protective File Album 


е 8 Special 50-Foot Cassettes - Ideal for 
Building Up Your 99'er Program Library 


€ Economical As It Is Functional 
5х Only $9.95 each; ог З for $27.00 


Add $2.00 shipping and handling. Use the bind-in card in the 
back of the magazine for your convenience in ordering. Tele- 
phone orders accepted if charged to credit cards. 


тм 
INNOVATIVE PRODUCTS 
FOR TMS9900-BAS: 
PERSONAL COMPUTING 


P.O. Box 5537 
Eugene, Oregon 97405 
Tel. (503) 485-8796 


TESTED AT М.І.Г.-- А STRATEGY 
FOR TURNING COMPUTERS 
INTO EFFECTIVE LEARNING TOOLS 


Drawing on 10 years of research 
of the LOGO group at the Massa- 
chusetts Institute of Technology 
eminent educator Seymour Papert 
introduces in Mindstorms an inno- 
vative yet fully tested strategy that 
will turn computers into tools for 
individualized learning 

Dr. Papert challenges the con- 
ventional approach to computer- 
assisted learning—one in which 
computers program the children— 
and argues that children should 
program the computers. mastering 
the "powerful ideas" from science 
and mathematics. He shows. in a 
brilliant synthesis of mathematics 
and Piagetian theory. how “math 
phobia” is created in our class- 
rooms and can be overcome with 
the help of computers 


You'll Be Hearing 


A Lot About 
The TI LOGO 
Language. 

Be Among The 


First To Know 
What It’s 


All About... 


MINDSTORMS 


Children, Computers, and Powerful Ideas 
Seymour Papert 


$12.95 Plus $1.50 Shipping & Handling 


== BOOKSTORE 
P.O. BOX 5537 
EUGENE, OREGON 97405 
Tel. 503-485-8796 


